<?xml version="1.0" encoding="utf-8" standalone="yes"?><rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom"><channel><title>Project/Auto-Sec-Blogger on 코딩이 싫은 거북이</title><link>https://rebugui.github.io/categories/project/auto-sec-blogger/</link><description>Recent content in Project/Auto-Sec-Blogger on 코딩이 싫은 거북이</description><generator>Hugo -- gohugo.io</generator><language>ko-kr</language><lastBuildDate>Thu, 04 Jun 2026 21:48:43 +0900</lastBuildDate><atom:link href="https://rebugui.github.io/categories/project/auto-sec-blogger/index.xml" rel="self" type="application/rss+xml"/><item><title>[Open Source] 로컬 LLM·사람 검토 기반 보안 블로그 자동화 (auto-sec-blogger)</title><link>https://rebugui.github.io/open-source-%EB%A1%9C%EC%BB%AC-llm%EC%82%AC%EB%9E%8C-%EA%B2%80%ED%86%A0-%EA%B8%B0%EB%B0%98-%EB%B3%B4%EC%95%88-%EB%B8%94%EB%A1%9C%EA%B7%B8-%EC%9E%90%EB%8F%99%ED%99%94-auto-sec-blogger/</link><pubDate>Thu, 04 Jun 2026 21:48:43 +0900</pubDate><guid>https://rebugui.github.io/open-source-%EB%A1%9C%EC%BB%AC-llm%EC%82%AC%EB%9E%8C-%EA%B2%80%ED%86%A0-%EA%B8%B0%EB%B0%98-%EB%B3%B4%EC%95%88-%EB%B8%94%EB%A1%9C%EA%B7%B8-%EC%9E%90%EB%8F%99%ED%99%94-auto-sec-blogger/</guid><description>&lt;h2 id="-개요"&gt;📋 개요
&lt;/h2&gt;&lt;p&gt;보안·기술 뉴스를 자동으로 수집하고, &lt;strong&gt;로컬 LLM(Ollama Gemma4)&lt;/strong&gt; 으로 글 초안을 작성한 뒤, &lt;strong&gt;사람이 검토·승인한 글만&lt;/strong&gt; GitHub Pages 블로그에 발행하는 지능형 에이전트 &lt;strong&gt;auto-sec-blogger&lt;/strong&gt;를 소개합니다. 지금 보고 계신 이 블로그가 바로 이 도구로 운영됩니다.&lt;/p&gt;
&lt;blockquote&gt;
&lt;p&gt;&lt;strong&gt;GitHub 저장소:&lt;/strong&gt; &lt;a class="link" href="https://github.com/rebugui/auto-sec-blogger" target="_blank" rel="noopener"
 &gt;https://github.com/rebugui/auto-sec-blogger&lt;/a&gt;&lt;/p&gt;
&lt;/blockquote&gt;
&lt;h2 id="-제작-배경"&gt;🎯 제작 배경
&lt;/h2&gt;&lt;p&gt;매일 쏟아지는 보안 뉴스를 사람이 일일이 정리해 글로 쓰는 것은 비효율적입니다. 그렇다고 LLM에 전부 맡겨 자동 발행하면 품질·사실성 관리가 어렵습니다. 그래서 &lt;strong&gt;생성은 자동, 공개는 사람 승인&lt;/strong&gt;이라는 Human-in-the-Loop 원칙으로 설계했고, 클라우드 비용·프라이버시를 피하려 &lt;strong&gt;외부 호출 없는 로컬 모델&lt;/strong&gt;을 사용합니다.&lt;/p&gt;
&lt;h2 id="-파이프라인-구조"&gt;🏗️ 파이프라인 구조
&lt;/h2&gt;&lt;div class="highlight"&gt;&lt;div class="chroma"&gt;
&lt;table class="lntable"&gt;&lt;tr&gt;&lt;td class="lntd"&gt;
&lt;pre tabindex="0" class="chroma"&gt;&lt;code&gt;&lt;span class="lnt"&gt; 1
&lt;/span&gt;&lt;span class="lnt"&gt; 2
&lt;/span&gt;&lt;span class="lnt"&gt; 3
&lt;/span&gt;&lt;span class="lnt"&gt; 4
&lt;/span&gt;&lt;span class="lnt"&gt; 5
&lt;/span&gt;&lt;span class="lnt"&gt; 6
&lt;/span&gt;&lt;span class="lnt"&gt; 7
&lt;/span&gt;&lt;span class="lnt"&gt; 8
&lt;/span&gt;&lt;span class="lnt"&gt; 9
&lt;/span&gt;&lt;span class="lnt"&gt;10
&lt;/span&gt;&lt;span class="lnt"&gt;11
&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/td&gt;
&lt;td class="lntd"&gt;
&lt;pre tabindex="0" class="chroma"&gt;&lt;code class="language-plain" data-lang="plain"&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;뉴스 수집 (Google News · arXiv · HackerNews · Hada.io)
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt; ↓
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;Ollama Gemma4 평가/선별 (카테고리별 점수 · round-robin)
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt; ↓
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;Ollama Gemma4 글 작성 (멀티 페르소나: 보안/AI/DevOps/CVE)
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt; ↓
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;Notion 저장 (초안 작성중 → 검토중)
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt; ↓
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;[사람 검토] 검토중 → 검토 완료 로 승인
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt; ↓
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;Hugo content/post 생성 → git push → GitHub Pages 배포
&lt;/span&gt;&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;
&lt;/div&gt;
&lt;/div&gt;&lt;p&gt;&lt;strong&gt;핵심 설계&lt;/strong&gt;&lt;/p&gt;
&lt;ul&gt;
&lt;li&gt;&lt;strong&gt;로컬 LLM&lt;/strong&gt;: &lt;code&gt;gemma4:e4b&lt;/code&gt; (OpenAI 호환 &lt;code&gt;localhost:11434&lt;/code&gt;), 외부 클라우드 호출 없음&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;견고한 선별&lt;/strong&gt;: 카테고리 후보 제한 + 청크 분할 + &lt;code&gt;json_mode&lt;/code&gt; + 복구 파싱으로 LLM 응답 잘림에 대비&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;멀티 페르소나 작성&lt;/strong&gt;: 보안·AI/ML·DevOps·CVE 전문가 톤, Mermaid 다이어그램·표 포함&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;상태 관리&lt;/strong&gt;: Notion에서 초안→검토중→검토 완료→게시 완료 추적, 중복 발행 방지&lt;/li&gt;
&lt;/ul&gt;
&lt;h2 id="-라이선스--발행-대상"&gt;⚖️ 라이선스 / 발행 대상
&lt;/h2&gt;&lt;p&gt;&lt;strong&gt;MIT License&lt;/strong&gt;. 발행 대상은 &lt;strong&gt;GitHub Pages(Hugo)&lt;/strong&gt; 전용입니다. 네이버·티스토리 자동 발행도 검토했으나, 두 플랫폼 모두 글쓰기 시 캡차(네이버 자동등록방지 / 티스토리 DKAPTCHA 지도 캡차)로 봇 발행을 차단해 제외했습니다.&lt;/p&gt;
&lt;h2 id="-주의사항"&gt;⚠️ 주의사항
&lt;/h2&gt;&lt;ul&gt;
&lt;li&gt;로컬 Gemma4 작성은 느릴 수 있어 스케줄러 타임아웃을 넉넉히(예: 1800초) 두는 것이 좋습니다.&lt;/li&gt;
&lt;li&gt;Notion 토큰·블로그 DB ID·GitHub 토큰 등 환경 변수 설정이 선행돼야 합니다.&lt;/li&gt;
&lt;li&gt;완전 자동 발행을 원하면 &lt;code&gt;AUTO_PUBLISH_STATUS=검토중&lt;/code&gt;으로 바꿀 수 있으나, 품질 관리를 위해 사람 검토를 권장합니다.&lt;/li&gt;
&lt;/ul&gt;
&lt;h2 id="-실행-방법"&gt;🚀 실행 방법
&lt;/h2&gt;&lt;div class="highlight"&gt;&lt;div class="chroma"&gt;
&lt;table class="lntable"&gt;&lt;tr&gt;&lt;td class="lntd"&gt;
&lt;pre tabindex="0" class="chroma"&gt;&lt;code&gt;&lt;span class="lnt"&gt;1
&lt;/span&gt;&lt;span class="lnt"&gt;2
&lt;/span&gt;&lt;span class="lnt"&gt;3
&lt;/span&gt;&lt;span class="lnt"&gt;4
&lt;/span&gt;&lt;span class="lnt"&gt;5
&lt;/span&gt;&lt;span class="lnt"&gt;6
&lt;/span&gt;&lt;span class="lnt"&gt;7
&lt;/span&gt;&lt;span class="lnt"&gt;8
&lt;/span&gt;&lt;span class="lnt"&gt;9
&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/td&gt;
&lt;td class="lntd"&gt;
&lt;pre tabindex="0" class="chroma"&gt;&lt;code class="language-bash" data-lang="bash"&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;&lt;span class="c1"&gt;# 설치&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;pip3 install -r scripts/requirements.txt
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;ollama pull gemma4:e4b
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;&lt;span class="c1"&gt;# 파이프라인 (Notion 초안까지)&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;python3 scripts/intelligence_pipeline.py --max-articles &lt;span class="m"&gt;3&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;&lt;span class="c1"&gt;# 승인된 글 발행 (1건 테스트)&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;&lt;span class="nv"&gt;AUTO_PUBLISH_MAX&lt;/span&gt;&lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="m"&gt;1&lt;/span&gt; python3 scripts/auto_publish_approved.py
&lt;/span&gt;&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;
&lt;/div&gt;
&lt;/div&gt;&lt;h2 id="-피드백"&gt;💬 피드백
&lt;/h2&gt;&lt;p&gt;개선 제안·버그·풀 리퀘스트를 환영합니다. &lt;strong&gt;&lt;a class="link" href="https://github.com/rebugui/auto-sec-blogger/issues" target="_blank" rel="noopener"
 &gt;GitHub Issues&lt;/a&gt;&lt;/strong&gt; 로 알려 주세요.&lt;/p&gt;</description></item></channel></rss>