[{"data":1,"prerenderedAt":4158},["ShallowReactive",2],{"posts-tag-llm":3},[4,112,704,2140,2920,3829],{"id":5,"title":6,"body":7,"date":100,"description":101,"extension":102,"meta":103,"navigation":104,"path":105,"seo":106,"stem":107,"tags":108,"__hash__":111},"blog\u002Fblog\u002Fmuryoudemisskey.md","ほぼ無料でMisskeyインスタンスを立てたよ",{"type":8,"value":9,"toc":88},"minimark",[10,14,29,32,35,39,50,53,56,68,71,82,85],[11,12,13],"h2",{"id":13},"ほぼ無料",[15,16,17,18,21,28],"p",{},"私はMisskeyのインスタンスを立てました。",[19,20],"br",{},[22,23,27],"a",{"href":24,"rel":25},"https:\u002F\u002Fmsk.samenoko.work",[26],"nofollow","ここから","から見ることが出来ます。",[15,30,31],{},"これを運営するにあたってほとんどお金がかかりません。(電気代を除く)",[11,33,34],{"id":34},"スタック",[36,37,38],"h3",{"id":38},"サーバー",[15,40,41,42,46,47,49],{},"まずMisskeyを動かしているサーバーは",[43,44,45],"strong",{},"自宅サーバー","です。",[19,48],{},"\n毎月固定でお金がかかるわけではないので素晴らしいです。イニシャルコストはかかりますけど。",[15,51,52],{},"電気代は除きます。",[36,54,55],{"id":55},"公開",[15,57,58,59,64,65,67],{},"インターネットへの公開は",[22,60,63],{"href":61,"rel":62},"https:\u002F\u002Fdevelopers.cloudflare.com\u002Fcloudflare-one\u002Fnetworks\u002Fconnectors\u002Fcloudflare-tunnel\u002F",[26],"Cloudflare Tunnel","を使用しています。",[19,66],{},"\nポート開放が不要でついでにHTTPSになるし、DDoS保護も付いてくる。",[36,69,70],{"id":70},"メール",[15,72,73,74,64,79,81],{},"パスワードの再設定などのお知らせメールを配信するために",[22,75,78],{"href":76,"rel":77},"https:\u002F\u002Fresend.com\u002F",[26],"Resend",[19,80],{},"\nユーザー数なんて無いから無料枠に収まります。",[36,83,84],{"id":84},"オブジェクトストレージ",[15,86,87],{},"オブジェクトストレージにはCloudflare R2を使用しています。",{"title":89,"searchDepth":90,"depth":90,"links":91},"",2,[92,93],{"id":13,"depth":90,"text":13},{"id":34,"depth":90,"text":34,"children":94},[95,97,98,99],{"id":38,"depth":96,"text":38},3,{"id":55,"depth":96,"text":55},{"id":70,"depth":96,"text":70},{"id":84,"depth":96,"text":84},"2026-04-09","ほぼ無料でMisskeyインスタンスを立てただけ","md",{},true,"\u002Fblog\u002Fmuryoudemisskey",{"title":6,"description":101},"blog\u002Fmuryoudemisskey",[109],{"name":110},"雑記","h-Encg2X51Tq0ci0X1FpP2IR0bX5GYlHdlcuB5cBDVo",{"id":113,"title":114,"body":115,"date":100,"description":691,"extension":102,"meta":692,"navigation":104,"path":693,"seo":694,"stem":695,"tags":696,"__hash__":703},"blog\u002Fblog\u002Fsumaho-de-qwen.md","Qwen3.5をAndroidスマホで動かしてみよう！(not 実用的)",{"type":8,"value":116,"toc":682},[117,121,124,127,130,133,149,152,156,216,222,251,254,304,307,341,344,347,350,376,380,420,426,481,484,503,506,519,530,533,536,576,579,613,620,625,628,633,636,641,644,652,655,658,663,666,669,675,678],[11,118,120],{"id":119},"え-androidスマホでllmを","え!! AndroidスマホでLLMを!?",[15,122,123],{},"出来らあっ！",[15,125,126],{},"…。始めます。",[11,128,129],{"id":129},"今回の環境",[15,131,132],{},"Galaxy S26 12\u002F256GBを使います。",[134,135,136,140,143,146],"ul",{},[137,138,139],"li",{},"Snapdragon 8 Elite gen 5",[137,141,142],{},"DDR5X 12GB",[137,144,145],{},"UFS4.1 256GB",[137,147,148],{},"Android 16",[15,150,151],{},"みたいな感じです。一応最新ハイエンド。",[11,153,155],{"id":154},"termuxの準備","Termuxの準備",[157,158,161,162],"div",{"className":159},[160],"remark-link-card-plus__container","\n  ",[22,163,171,172,207,161],{"href":164,"target":165,"rel":166,"className":169},"https:\u002F\u002Ff-droid.org\u002Fja\u002Fpackages\u002Fcom.termux\u002F","_blank",[167,168],"noreferrer","noopener",[170],"remark-link-card-plus__card","\n    ",[157,173,161,176,161,190],{"className":174},[175],"remark-link-card-plus__main",[157,177,171,180,171,185,161],{"className":178},[179],"remark-link-card-plus__content",[157,181,184],{"className":182},[183],"remark-link-card-plus__title","Termux | F-Droid - 自由かつオープンソースのAndroidアプリ・リポジトリ",[157,186,189],{"className":187},[188],"remark-link-card-plus__description","パッケージを伴ったターミナル・エミュレーター",[157,191,171,194,171,201,161],{"className":192},[193],"remark-link-card-plus__meta",[195,196],"img",{"src":197,"className":198,"width":200,"height":200,"alt":89},"https:\u002F\u002Ff-droid.org\u002Fassets\u002Ffavicon_yJPr4UNteJc-cseeq16P0Hvl1kDbJjTVYcj-KA6-_Fs=.ico",[199],"remark-link-card-plus__favicon",14,[202,203,206],"span",{"className":204},[205],"remark-link-card-plus__url","f-droid.org",[157,208,161,211],{"className":209},[210],"remark-link-card-plus__thumbnail",[195,212],{"src":213,"className":214,"alt":89},"https:\u002F\u002Ff-droid.org\u002Frepo\u002Fcom.termux\u002Fen-US\u002Ficon_7jMZ7XD80oeucmGEaTwktIRZexLtGWvJfKdVD6Wu2SI=.png",[215],"remark-link-card-plus__image",[15,217,218,219,221],{},"からapkをダウンロードして、インストールします。",[19,220],{},"\n起動したらミラーの最適化とパッケージのアップデートを行いましょう。",[223,224,228],"pre",{"className":225,"code":226,"language":227,"meta":89,"style":89},"language-shell shiki shiki-themes catppuccin-macchiato","termux-change-repo\npkg upgrade -y\n","shell",[229,230,231,239],"code",{"__ignoreMap":89},[202,232,235],{"class":233,"line":234},"line",1,[202,236,238],{"class":237},"siK8c","termux-change-repo\n",[202,240,241,244,248],{"class":233,"line":90},[202,242,243],{"class":237},"pkg",[202,245,247],{"class":246},"sSZ1V"," upgrade",[202,249,250],{"class":246}," -y\n",[15,252,253],{},"完全に蛇足ですが、私はSSHできるようにしておきました。",[223,255,257],{"className":225,"code":256,"language":227,"meta":89,"style":89},"# sshと自動起動用のパッケージをインストール\npkg install openssh termux-services\n# パスワードを設定\npasswd\n# 自動起動の設定\nsv-enable sshd\n",[229,258,259,265,278,283,289,295],{"__ignoreMap":89},[202,260,261],{"class":233,"line":234},[202,262,264],{"class":263},"sfEIy","# sshと自動起動用のパッケージをインストール\n",[202,266,267,269,272,275],{"class":233,"line":90},[202,268,243],{"class":237},[202,270,271],{"class":246}," install",[202,273,274],{"class":246}," openssh",[202,276,277],{"class":246}," termux-services\n",[202,279,280],{"class":233,"line":96},[202,281,282],{"class":263},"# パスワードを設定\n",[202,284,286],{"class":233,"line":285},4,[202,287,288],{"class":237},"passwd\n",[202,290,292],{"class":233,"line":291},5,[202,293,294],{"class":263},"# 自動起動の設定\n",[202,296,298,301],{"class":233,"line":297},6,[202,299,300],{"class":237},"sv-enable",[202,302,303],{"class":246}," sshd\n",[15,305,306],{},"接続するときは",[223,308,310],{"className":225,"code":309,"language":227,"meta":89,"style":89},"ssh a@\u003CスマホのIP> -p 8022\n",[229,311,312],{"__ignoreMap":89},[202,313,314,317,320,324,327,331,334,337],{"class":233,"line":234},[202,315,316],{"class":237},"ssh",[202,318,319],{"class":246}," a@",[202,321,323],{"class":322},"sXptk","\u003C",[202,325,326],{"class":246},"スマホのI",[202,328,330],{"class":329},"sFaBz","P",[202,332,333],{"class":322},">",[202,335,336],{"class":246}," -p",[202,338,340],{"class":339},"s7Qn8"," 8022\n",[15,342,343],{},"ユーザー名は何を指定しても大丈夫です。",[11,345,346],{"id":346},"必須パッケージのインストール",[15,348,349],{},"今回はllama.cppを使用して動かすので、ビルドするために必要なパッケージを入れていきます。",[223,351,353],{"className":225,"code":352,"language":227,"meta":89,"style":89},"pkg install git clang cmake wget libandroid-spawn\n",[229,354,355],{"__ignoreMap":89},[202,356,357,359,361,364,367,370,373],{"class":233,"line":234},[202,358,243],{"class":237},[202,360,271],{"class":246},[202,362,363],{"class":246}," git",[202,365,366],{"class":246}," clang",[202,368,369],{"class":246}," cmake",[202,371,372],{"class":246}," wget",[202,374,375],{"class":246}," libandroid-spawn\n",[11,377,379],{"id":378},"llamacppのビルド","llama.cppのビルド",[157,381,161,383],{"className":382},[160],[22,384,171,388,413,161],{"href":385,"target":165,"rel":386,"className":387},"https:\u002F\u002Fgithub.com\u002Fggml-org\u002Fllama.cpp",[167,168],[170],[157,389,161,391,161,402],{"className":390},[175],[157,392,171,394,171,398,161],{"className":393},[179],[157,395,397],{"className":396},[183],"GitHub - ggml-org\u002Fllama.cpp: LLM inference in C\u002FC++",[157,399,401],{"className":400},[188],"LLM inference in C\u002FC++. Contribute to ggml-org\u002Fllama.cpp development by creating an account on GitHub.",[157,403,171,405,171,409,161],{"className":404},[193],[195,406],{"src":407,"className":408,"width":200,"height":200,"alt":89},"https:\u002F\u002Fgithub.githubassets.com\u002Ffavicons\u002Ffavicon.svg",[199],[202,410,412],{"className":411},[205],"github.com",[157,414,161,416],{"className":415},[210],[195,417],{"src":418,"className":419,"alt":89},"https:\u002F\u002Frepository-images.githubusercontent.com\u002F612354784\u002Fc59e3320-a236-4182-941f-ea3f1a0f50e7",[215],[15,421,422,423,425],{},"を使ってLLMを動かします。",[19,424],{},"\nまずはビルドを行いますよ。",[223,427,429],{"className":225,"code":428,"language":227,"meta":89,"style":89},"git clone https:\u002F\u002Fgithub.com\u002Fggml-org\u002Fllama.cpp.git\ncd llama.cpp\ncmake -B build\ncmake --build build --config Release -j6\n",[229,430,431,442,451,462],{"__ignoreMap":89},[202,432,433,436,439],{"class":233,"line":234},[202,434,435],{"class":237},"git",[202,437,438],{"class":246}," clone",[202,440,441],{"class":246}," https:\u002F\u002Fgithub.com\u002Fggml-org\u002Fllama.cpp.git\n",[202,443,444,448],{"class":233,"line":90},[202,445,447],{"class":446},"sizsb","cd",[202,449,450],{"class":246}," llama.cpp\n",[202,452,453,456,459],{"class":233,"line":96},[202,454,455],{"class":237},"cmake",[202,457,458],{"class":246}," -B",[202,460,461],{"class":246}," build\n",[202,463,464,466,469,472,475,478],{"class":233,"line":285},[202,465,455],{"class":237},[202,467,468],{"class":246}," --build",[202,470,471],{"class":246}," build",[202,473,474],{"class":246}," --config",[202,476,477],{"class":246}," Release",[202,479,480],{"class":246}," -j6\n",[15,482,483],{},"ビルド中にエラーで落ちることがあります。その際は",[223,485,487],{"className":225,"code":486,"language":227,"meta":89,"style":89},"cmake --build build --config Release -j6\n",[229,488,489],{"__ignoreMap":89},[202,490,491,493,495,497,499,501],{"class":233,"line":234},[202,492,455],{"class":237},[202,494,468],{"class":246},[202,496,471],{"class":246},[202,498,474],{"class":246},[202,500,477],{"class":246},[202,502,480],{"class":246},[15,504,505],{},"を連打すると終わります。",[223,507,509],{"className":225,"code":508,"language":227,"meta":89,"style":89},"ls .\u002Fbuild\u002Fbin\n",[229,510,511],{"__ignoreMap":89},[202,512,513,516],{"class":233,"line":234},[202,514,515],{"class":237},"ls",[202,517,518],{"class":246}," .\u002Fbuild\u002Fbin\n",[15,520,521,522,525,526,529],{},"で",[229,523,524],{},"llama-server","とか",[229,527,528],{},"llama-cli","が見えればOKです。",[11,531,532],{"id":532},"動かしてみる",[15,534,535],{},"さて動かしてみますよ。Qwenを。今回はunslothのQwen3.5-0.8B-GGUFを動かしてみます。",[157,537,161,539],{"className":538},[160],[22,540,171,544,569,161],{"href":541,"target":165,"rel":542,"className":543},"https:\u002F\u002Fhuggingface.co\u002Funsloth\u002FQwen3.5-0.8B-GGUF",[167,168],[170],[157,545,161,547,161,558],{"className":546},[175],[157,548,171,550,171,554,161],{"className":549},[179],[157,551,553],{"className":552},[183],"unsloth\u002FQwen3.5-0.8B-GGUF · Hugging Face",[157,555,557],{"className":556},[188],"We’re on a journey to advance and democratize artificial intelligence through open source and open science.",[157,559,171,561,171,565,161],{"className":560},[193],[195,562],{"src":563,"className":564,"width":200,"height":200,"alt":89},"https:\u002F\u002Fwww.google.com\u002Fs2\u002Ffavicons?domain=huggingface.co",[199],[202,566,568],{"className":567},[205],"huggingface.co",[157,570,161,572],{"className":571},[210],[195,573],{"src":574,"className":575,"alt":89},"https:\u002F\u002Fcdn-thumbnails.huggingface.co\u002Fsocial-thumbnails\u002Fmodels\u002Funsloth\u002FQwen3.5-0.8B-GGUF.png",[215],[15,577,578],{},"次のコマンドを実行します。",[223,580,582],{"className":225,"code":581,"language":227,"meta":89,"style":89},".\u002Fbuild\u002Fbin\u002Fllama-server -hf unsloth\u002FQwen3.5-0.8B-GGUF --host 0.0.0.0 --port 2323 --reasoning-budget 0\n",[229,583,584],{"__ignoreMap":89},[202,585,586,589,592,595,598,601,604,607,610],{"class":233,"line":234},[202,587,588],{"class":237},".\u002Fbuild\u002Fbin\u002Fllama-server",[202,590,591],{"class":246}," -hf",[202,593,594],{"class":246}," unsloth\u002FQwen3.5-0.8B-GGUF",[202,596,597],{"class":246}," --host",[202,599,600],{"class":339}," 0.0.0.0",[202,602,603],{"class":246}," --port",[202,605,606],{"class":339}," 2323",[202,608,609],{"class":246}," --reasoning-budget",[202,611,612],{"class":339}," 0\n",[15,614,615,616,619],{},"この状態で",[229,617,618],{},"http:\u002F\u002F\u003CスマホのIP>:2323","にアクセスすると…。",[15,621,622],{},[195,623],{"alt":89,"src":624},"https:\u002F\u002Fstorage.googleapis.com\u002Fzenn-user-upload\u002Fe032c563fd07-20260406.png",[15,626,627],{},"こんな画面が出ます。適当に会話を試みましょう。",[15,629,630],{},[195,631],{"alt":89,"src":632},"https:\u002F\u002Fstorage.googleapis.com\u002Fzenn-user-upload\u002F569cef96f1ec-20260406.png",[15,634,635],{},"日本語は荷が重そうです。",[15,637,638],{},[195,639],{"alt":89,"src":640},"https:\u002F\u002Fstorage.googleapis.com\u002Fzenn-user-upload\u002Fd83426738787-20260406.png",[15,642,643],{},"私は英弱なので翻訳を。",[223,645,650],{"className":646,"code":648,"language":649},[647],"language-text","こんにちは！私はTongyi Labが開発した最新の大規模言語モデル、Qwen3.5です。\n膨大なテキストコーパスで学習済みで、質問への回答からクリエイティブなコンテンツの生成まで、幅広いタスクでお手伝いできます。今日はどのようなお手伝いができますか？😊\n","text",[229,651,648],{"__ignoreMap":89},[15,653,654],{},"開発元はアリババな気もしますけど、なにせ0.8Bなので。気にしない気にしない。",[15,656,657],{},"生成自体は1.4トークン\u002F秒と激遅です。ちなみに私のメインパソコン(R7 5770X+RTX 4060 Ti)では",[15,659,660],{},[195,661],{"alt":89,"src":662},"https:\u002F\u002Fstorage.googleapis.com\u002Fzenn-user-upload\u002Fce80ba874e37-20260406.png",[15,664,665],{},"216トークン\u002F秒です。こっちはGPUでAndroidはCPUですからね。分が悪いレベルの話ではないのですけど。",[11,667,668],{"id":668},"以上",[15,670,671,672,674],{},"以上です。完全に自己満足ですが、一応動いたのに驚いてます。",[19,673],{},"\nできればOpenCLを使った推論もやらせてみたいですね。出来たらですけど。",[15,676,677],{},"それでは！",[679,680,681],"style",{},"html pre.shiki code .siK8c, html code.shiki .siK8c{--shiki-default:#8AADF4;--shiki-default-font-style:italic}html pre.shiki code .sSZ1V, html code.shiki .sSZ1V{--shiki-default:#A6DA95}html .default .shiki span {color: var(--shiki-default);background: var(--shiki-default-bg);font-style: var(--shiki-default-font-style);font-weight: var(--shiki-default-font-weight);text-decoration: var(--shiki-default-text-decoration);}html .shiki span {color: var(--shiki-default);background: var(--shiki-default-bg);font-style: var(--shiki-default-font-style);font-weight: var(--shiki-default-font-weight);text-decoration: var(--shiki-default-text-decoration);}html pre.shiki code .sfEIy, html code.shiki .sfEIy{--shiki-default:#939AB7;--shiki-default-font-style:italic}html pre.shiki code .sXptk, html code.shiki .sXptk{--shiki-default:#8BD5CA}html pre.shiki code .sFaBz, html code.shiki .sFaBz{--shiki-default:#CAD3F5}html pre.shiki code .s7Qn8, html code.shiki .s7Qn8{--shiki-default:#F5A97F}html pre.shiki code .sizsb, html code.shiki .sizsb{--shiki-default:#ED8796;--shiki-default-font-style:italic}",{"title":89,"searchDepth":90,"depth":90,"links":683},[684,685,686,687,688,689,690],{"id":119,"depth":90,"text":120},{"id":129,"depth":90,"text":129},{"id":154,"depth":90,"text":155},{"id":346,"depth":90,"text":346},{"id":378,"depth":90,"text":379},{"id":532,"depth":90,"text":532},{"id":668,"depth":90,"text":668},"Qwen3.5をAndroidスマホで動かしてみたかったログ",{},"\u002Fblog\u002Fsumaho-de-qwen",{"title":114,"description":691},"blog\u002Fsumaho-de-qwen",[697,699,701],{"name":698},"Android",{"name":700},"Termux",{"name":702},"llama.cpp","6ze60E6sxTxUHYMddQ-Yqm0WvHbCISPRQmhv6Rg-htY",{"id":705,"title":706,"body":707,"date":2129,"description":2130,"extension":102,"meta":2131,"navigation":104,"path":2132,"seo":2133,"stem":2134,"tags":2135,"__hash__":2139},"blog\u002Fblog\u002Fanime-encode-study.md","アニメエンコードの研究(笑)",{"type":8,"value":708,"toc":2103},[709,712,715,718,721,725,763,769,772,775,818,821,827,830,836,842,848,851,857,863,869,872,875,878,951,954,960,966,972,978,984,987,993,996,1002,1005,1011,1014,1017,1020,2054,2057,2061,2067,2072,2077,2080,2083,2086,2089,2092,2098,2100],[11,710,711],{"id":711},"アニメエンコード",[15,713,714],{},"録画などを容量節約のために高効率なコーデックで再エンコードをすることです。",[15,716,717],{},"元データが大体1.4GBで大体300~400MBくらいに削減できるような設定を狙っていきます。",[11,719,720],{"id":720},"使用するツール",[36,722,724],{"id":723},"nvenc","NVEnc",[157,726,161,728],{"className":727},[160],[22,729,171,733,756,161],{"href":730,"target":165,"rel":731,"className":732},"https:\u002F\u002Fgithub.com\u002Frigaya\u002FNVEnc",[167,168],[170],[157,734,161,736,161,747],{"className":735},[175],[157,737,171,739,171,743,161],{"className":738},[179],[157,740,742],{"className":741},[183],"GitHub - rigaya\u002FNVEnc: NVENCによる高速エンコードの性能実験",[157,744,746],{"className":745},[188],"NVENCによる高速エンコードの性能実験. Contribute to rigaya\u002FNVEnc development by creating an account on GitHub.",[157,748,171,750,171,753,161],{"className":749},[193],[195,751],{"src":407,"className":752,"width":200,"height":200,"alt":89},[199],[202,754,412],{"className":755},[205],[157,757,161,759],{"className":758},[210],[195,760],{"src":761,"className":762,"alt":89},"https:\u002F\u002Fopengraph.githubassets.com\u002F9febcaf3aa6b3e42e58e7c3f0204086035c14995646f335a1005436ac6c6f56f\u002Frigaya\u002FNVEnc",[215],[15,764,765,766,768],{},"rigaya氏が開発しているツールです。性能と画質を調査することを目的としているソフトウェアらしいですが、普通にツールとして利用可能です。",[19,767],{},"\nというかそっちが目的でしょ。しらんけど。",[11,770,771],{"id":771},"コマンド",[15,773,774],{},"基本的なコマンドは次の通り。",[223,776,778],{"className":225,"code":777,"language":227,"meta":89,"style":89},"nvencc -i \"input.mkv\" --avhw -c hevc --audio-codec libopus --audio-bitrate 128 -o \"output.mkv\"\n",[229,779,780],{"__ignoreMap":89},[202,781,782,785,788,791,794,797,800,803,806,809,812,815],{"class":233,"line":234},[202,783,784],{"class":237},"nvencc",[202,786,787],{"class":246}," -i",[202,789,790],{"class":246}," \"input.mkv\"",[202,792,793],{"class":246}," --avhw",[202,795,796],{"class":246}," -c",[202,798,799],{"class":246}," hevc",[202,801,802],{"class":246}," --audio-codec",[202,804,805],{"class":246}," libopus",[202,807,808],{"class":246}," --audio-bitrate",[202,810,811],{"class":339}," 128",[202,813,814],{"class":246}," -o",[202,816,817],{"class":246}," \"output.mkv\"\n",[15,819,820],{},"各オプションの解説をしておきます。",[36,822,824],{"id":823},"i-inputmkv",[229,825,826],{},"-i “input.mkv“",[15,828,829],{},"ファイルを入力します。",[36,831,833],{"id":832},"avhw",[229,834,835],{},"--avhw",[15,837,838,839,841],{},"ファイルの読み込みにGPUを使用する。h264であれば使用可能。",[19,840],{},"\nCPUを使用するよりも高速です。",[36,843,845],{"id":844},"c-hevc",[229,846,847],{},"-c hevc",[15,849,850],{},"使用するコーデックを選択します。割とどの環境でも再生可能なhevcを選択しています。",[36,852,854],{"id":853},"audio-codec-libopus-audio-bitrate-128",[229,855,856],{},"--audio-codec libopus --audio-bitrate 128",[15,858,859,860,862],{},"音声をopusでエンコードする。ビットレートは128kbpsです。",[19,861],{},"\nWindowsのメディアプレイヤー以外なら再生できる。",[36,864,866],{"id":865},"o-outputmkv",[229,867,868],{},"-o \"output.mkv\"",[15,870,871],{},"出力ファイル。",[11,873,874],{"id":874},"現時点で使用しているコマンド",[15,876,877],{},"私が今使っているコマンドです。",[223,879,881],{"className":225,"code":880,"language":227,"meta":89,"style":89},"nvencc -i \"input.mkv\" --avhw -c hevc --qvbr 24 -u P6 --output-depth 10 --lookahead 32 -b 4 --bref-mode each --aq --aq-temporal --audio-codec libopus --audio-bitrate 128 -o \"output.mkv\"\n",[229,882,883],{"__ignoreMap":89},[202,884,885,887,889,891,893,895,897,900,903,906,909,912,915,918,921,924,927,930,933,936,939,941,943,945,947,949],{"class":233,"line":234},[202,886,784],{"class":237},[202,888,787],{"class":246},[202,890,790],{"class":246},[202,892,793],{"class":246},[202,894,796],{"class":246},[202,896,799],{"class":246},[202,898,899],{"class":246}," --qvbr",[202,901,902],{"class":339}," 24",[202,904,905],{"class":246}," -u",[202,907,908],{"class":246}," P6",[202,910,911],{"class":246}," --output-depth",[202,913,914],{"class":339}," 10",[202,916,917],{"class":246}," --lookahead",[202,919,920],{"class":339}," 32",[202,922,923],{"class":246}," -b",[202,925,926],{"class":339}," 4",[202,928,929],{"class":246}," --bref-mode",[202,931,932],{"class":246}," each",[202,934,935],{"class":246}," --aq",[202,937,938],{"class":246}," --aq-temporal",[202,940,802],{"class":246},[202,942,805],{"class":246},[202,944,808],{"class":246},[202,946,811],{"class":339},[202,948,814],{"class":246},[202,950,817],{"class":246},[15,952,953],{},"追加されたオプションの解説をしておきます。",[36,955,957],{"id":956},"qvbr-24",[229,958,959],{},"--qvbr 24",[15,961,962,963,965],{},"品質ベースの可変ビットレートです。24はそこそこって感じの値です。",[19,964],{},"\nもし画質が悪いようであれば値を小さくするといいです。ファイルサイズは大きくなりますけどね。",[36,967,969],{"id":968},"u-p6",[229,970,971],{},"-u P6",[15,973,974,975,977],{},"プリセットです。P6は画質と速度のバランスが最も良い値らしいです。",[19,976],{},"\n最も品質がいいのはP7。速度はあまり変わらない(10fpsくらい下がるだけ)",[36,979,981],{"id":980},"output-depth-10",[229,982,983],{},"--output-depth 10",[15,985,986],{},"10bitで出力する。背景のグラデーションなどが美しくなる。気持ち圧縮効率も上がるらしいですよ。",[36,988,990],{"id":989},"lookahead-32",[229,991,992],{},"--lookahead 32",[15,994,995],{},"先読みするフレーム数です。ビットレートの配分がいい感じになるそうです。",[36,997,999],{"id":998},"b-4-bref-mode-each",[229,1000,1001],{},"-b 4 --bref-mode each",[15,1003,1004],{},"Bフレームの設定です。Bフレームの参照をすべてのフレームにしています。",[36,1006,1008],{"id":1007},"aq-aq-temporal",[229,1009,1010],{},"--aq --aq-temporal",[15,1012,1013],{},"空間・時間的な最適量子化を有効にする。ビットレートの配分をいい感じにする設定。",[15,1015,1016],{},"というような設定です。",[15,1018,1019],{},"変換用のpyスクリプトも書いたので残しておく。",[223,1021,1026],{"className":1022,"code":1023,"filename":1024,"language":1025,"meta":89,"style":89},"language-python shiki shiki-themes catppuccin-macchiato","import subprocess\nfrom pathlib import Path\nimport tkinter as tk\nfrom tkinter import filedialog, messagebox\n\nEXTS = {\n    \".mkv\",\n    \".mp4\",\n    \".m2ts\"\n}\n\ndef pick_input_dir() -> Path | None:\n    root = tk.Tk()\n    root.withdraw()\n    root.attributes(\"-topmost\", True)\n    folder = filedialog.askdirectory(title=\"入力フォルダ\")\n    root.destroy()\n    return Path(folder) if folder else None\n\ndef process_videos(input_dir: Path) -> int:\n    output_dir = input_dir \u002F \"out\"\n    output_dir.mkdir(exist_ok=True)\n\n    count = 0\n    for path in input_dir.iterdir():\n        if not path.is_file():\n            continue\n        if path.suffix.lower() not in EXTS:\n            continue\n        output_path = output_dir \u002F path.name\n        cmd = [\n            \"nvencc\",\n            \"-i\", str(path),\n            \"--avhw\",\n            \"-c\", \"hevc\",\n            \"--qvbr\", \"24\",\n            \"-u\", \"P6\",\n            \"--output-depth\", \"10\",\n            \"--lookahead\", \"32\",\n            \"-b\", \"4\", \"--bref-mode\", \"each\",\n            \"--aq\", \"--aq-temporal\",\n            \"--audio-codec\", \"libopus\",\n            \"--audio-bitrate\", \"128\",\n            \"-o\", str(output_path)\n        ]\n\n        print(\"Running\",\" \".join(cmd))\n        result = subprocess.run(cmd)\n        if result.returncode != 0:\n            print(f\"Failed: {path.name}\")\n            continue\n        count += 1\n        print(f\"Done: {path.name} -> {output_path}\")\n\n    return count\n\ndef main() -> None:\n    input_dir = pick_input_dir()\n    if input_dir is None:\n        return\n\n    if not input_dir.exists() or not input_dir.is_dir():\n        messagebox.showerror(\"エラー\", \"有効なフォルダが選択されませんでした。\")\n        return\n\n    processed = process_videos(input_dir=input_dir)\n    messagebox.showinfo(\"完了\",f\"{processed}個の動画を処理しました\")\n\nif __name__ == \"__main__\":\n    main()\n","henkan.py","python",[229,1027,1028,1037,1050,1063,1081,1086,1097,1106,1114,1120,1126,1131,1158,1179,1191,1215,1243,1255,1284,1289,1318,1335,1358,1363,1373,1396,1415,1421,1450,1455,1475,1486,1494,1513,1521,1534,1547,1560,1573,1586,1609,1622,1635,1648,1665,1671,1676,1706,1728,1749,1783,1788,1800,1835,1840,1848,1853,1869,1881,1896,1902,1907,1937,1960,1965,1970,1990,2024,2029,2046],{"__ignoreMap":89},[202,1029,1030,1034],{"class":233,"line":234},[202,1031,1033],{"class":1032},"sIF4r","import",[202,1035,1036],{"class":329}," subprocess\n",[202,1038,1039,1042,1045,1047],{"class":233,"line":90},[202,1040,1041],{"class":1032},"from",[202,1043,1044],{"class":329}," pathlib ",[202,1046,1033],{"class":1032},[202,1048,1049],{"class":329}," Path\n",[202,1051,1052,1054,1057,1060],{"class":233,"line":96},[202,1053,1033],{"class":1032},[202,1055,1056],{"class":329}," tkinter ",[202,1058,1059],{"class":1032},"as",[202,1061,1062],{"class":329}," tk\n",[202,1064,1065,1067,1069,1071,1074,1078],{"class":233,"line":285},[202,1066,1041],{"class":1032},[202,1068,1056],{"class":329},[202,1070,1033],{"class":1032},[202,1072,1073],{"class":329}," filedialog",[202,1075,1077],{"class":1076},"slVFb",",",[202,1079,1080],{"class":329}," messagebox\n",[202,1082,1083],{"class":233,"line":291},[202,1084,1085],{"emptyLinePlaceholder":104},"\n",[202,1087,1088,1091,1094],{"class":233,"line":297},[202,1089,1090],{"class":329},"EXTS ",[202,1092,1093],{"class":322},"=",[202,1095,1096],{"class":1076}," {\n",[202,1098,1100,1103],{"class":233,"line":1099},7,[202,1101,1102],{"class":246},"    \".mkv\"",[202,1104,1105],{"class":1076},",\n",[202,1107,1109,1112],{"class":233,"line":1108},8,[202,1110,1111],{"class":246},"    \".mp4\"",[202,1113,1105],{"class":1076},[202,1115,1117],{"class":233,"line":1116},9,[202,1118,1119],{"class":246},"    \".m2ts\"\n",[202,1121,1123],{"class":233,"line":1122},10,[202,1124,1125],{"class":1076},"}\n",[202,1127,1129],{"class":233,"line":1128},11,[202,1130,1085],{"emptyLinePlaceholder":104},[202,1132,1134,1137,1140,1143,1146,1149,1152,1155],{"class":233,"line":1133},12,[202,1135,1136],{"class":1032},"def",[202,1138,1139],{"class":237}," pick_input_dir",[202,1141,1142],{"class":1076},"()",[202,1144,1145],{"class":1076}," ->",[202,1147,1148],{"class":329}," Path ",[202,1150,1151],{"class":322},"|",[202,1153,1154],{"class":339}," None",[202,1156,1157],{"class":1076},":\n",[202,1159,1161,1164,1166,1169,1172,1176],{"class":233,"line":1160},13,[202,1162,1163],{"class":329},"    root ",[202,1165,1093],{"class":322},[202,1167,1168],{"class":329}," tk",[202,1170,1171],{"class":1076},".",[202,1173,1175],{"class":1174},"s57MT","Tk",[202,1177,1178],{"class":1076},"()\n",[202,1180,1181,1184,1186,1189],{"class":233,"line":200},[202,1182,1183],{"class":329},"    root",[202,1185,1171],{"class":1076},[202,1187,1188],{"class":1174},"withdraw",[202,1190,1178],{"class":1076},[202,1192,1194,1196,1198,1201,1204,1207,1209,1212],{"class":233,"line":1193},15,[202,1195,1183],{"class":329},[202,1197,1171],{"class":1076},[202,1199,1200],{"class":1174},"attributes",[202,1202,1203],{"class":1076},"(",[202,1205,1206],{"class":246},"\"-topmost\"",[202,1208,1077],{"class":1076},[202,1210,1211],{"class":339}," True",[202,1213,1214],{"class":1076},")\n",[202,1216,1218,1221,1223,1225,1227,1230,1232,1236,1238,1241],{"class":233,"line":1217},16,[202,1219,1220],{"class":329},"    folder ",[202,1222,1093],{"class":322},[202,1224,1073],{"class":329},[202,1226,1171],{"class":1076},[202,1228,1229],{"class":1174},"askdirectory",[202,1231,1203],{"class":1076},[202,1233,1235],{"class":1234},"skVQi","title",[202,1237,1093],{"class":322},[202,1239,1240],{"class":246},"\"入力フォルダ\"",[202,1242,1214],{"class":1076},[202,1244,1246,1248,1250,1253],{"class":233,"line":1245},17,[202,1247,1183],{"class":329},[202,1249,1171],{"class":1076},[202,1251,1252],{"class":1174},"destroy",[202,1254,1178],{"class":1076},[202,1256,1258,1261,1264,1266,1269,1272,1275,1278,1281],{"class":233,"line":1257},18,[202,1259,1260],{"class":1032},"    return",[202,1262,1263],{"class":1174}," Path",[202,1265,1203],{"class":1076},[202,1267,1268],{"class":329},"folder",[202,1270,1271],{"class":1076},")",[202,1273,1274],{"class":1032}," if",[202,1276,1277],{"class":329}," folder ",[202,1279,1280],{"class":1032},"else",[202,1282,1283],{"class":339}," None\n",[202,1285,1287],{"class":233,"line":1286},19,[202,1288,1085],{"emptyLinePlaceholder":104},[202,1290,1292,1294,1297,1299,1302,1305,1308,1310,1312,1316],{"class":233,"line":1291},20,[202,1293,1136],{"class":1032},[202,1295,1296],{"class":237}," process_videos",[202,1298,1203],{"class":1076},[202,1300,1301],{"class":1234},"input_dir",[202,1303,1304],{"class":1076},":",[202,1306,1263],{"class":1307},"srmJT",[202,1309,1271],{"class":1076},[202,1311,1145],{"class":1076},[202,1313,1315],{"class":1314},"sxfwU"," int",[202,1317,1157],{"class":1076},[202,1319,1321,1324,1326,1329,1332],{"class":233,"line":1320},21,[202,1322,1323],{"class":329},"    output_dir ",[202,1325,1093],{"class":322},[202,1327,1328],{"class":329}," input_dir ",[202,1330,1331],{"class":322},"\u002F",[202,1333,1334],{"class":246}," \"out\"\n",[202,1336,1338,1341,1343,1346,1348,1351,1353,1356],{"class":233,"line":1337},22,[202,1339,1340],{"class":329},"    output_dir",[202,1342,1171],{"class":1076},[202,1344,1345],{"class":1174},"mkdir",[202,1347,1203],{"class":1076},[202,1349,1350],{"class":1234},"exist_ok",[202,1352,1093],{"class":322},[202,1354,1355],{"class":339},"True",[202,1357,1214],{"class":1076},[202,1359,1361],{"class":233,"line":1360},23,[202,1362,1085],{"emptyLinePlaceholder":104},[202,1364,1366,1369,1371],{"class":233,"line":1365},24,[202,1367,1368],{"class":329},"    count ",[202,1370,1093],{"class":322},[202,1372,612],{"class":339},[202,1374,1376,1379,1382,1385,1388,1390,1393],{"class":233,"line":1375},25,[202,1377,1378],{"class":1032},"    for",[202,1380,1381],{"class":329}," path ",[202,1383,1384],{"class":1032},"in",[202,1386,1387],{"class":329}," input_dir",[202,1389,1171],{"class":1076},[202,1391,1392],{"class":1174},"iterdir",[202,1394,1395],{"class":1076},"():\n",[202,1397,1399,1402,1405,1408,1410,1413],{"class":233,"line":1398},26,[202,1400,1401],{"class":1032},"        if",[202,1403,1404],{"class":1032}," not",[202,1406,1407],{"class":329}," path",[202,1409,1171],{"class":1076},[202,1411,1412],{"class":1174},"is_file",[202,1414,1395],{"class":1076},[202,1416,1418],{"class":233,"line":1417},27,[202,1419,1420],{"class":1032},"            continue\n",[202,1422,1424,1426,1428,1430,1433,1435,1438,1440,1442,1445,1448],{"class":233,"line":1423},28,[202,1425,1401],{"class":1032},[202,1427,1407],{"class":329},[202,1429,1171],{"class":1076},[202,1431,1432],{"class":329},"suffix",[202,1434,1171],{"class":1076},[202,1436,1437],{"class":1174},"lower",[202,1439,1142],{"class":1076},[202,1441,1404],{"class":1032},[202,1443,1444],{"class":1032}," in",[202,1446,1447],{"class":329}," EXTS",[202,1449,1157],{"class":1076},[202,1451,1453],{"class":233,"line":1452},29,[202,1454,1420],{"class":1032},[202,1456,1458,1461,1463,1466,1468,1470,1472],{"class":233,"line":1457},30,[202,1459,1460],{"class":329},"        output_path ",[202,1462,1093],{"class":322},[202,1464,1465],{"class":329}," output_dir ",[202,1467,1331],{"class":322},[202,1469,1407],{"class":329},[202,1471,1171],{"class":1076},[202,1473,1474],{"class":329},"name\n",[202,1476,1478,1481,1483],{"class":233,"line":1477},31,[202,1479,1480],{"class":329},"        cmd ",[202,1482,1093],{"class":322},[202,1484,1485],{"class":1076}," [\n",[202,1487,1489,1492],{"class":233,"line":1488},32,[202,1490,1491],{"class":246},"            \"nvencc\"",[202,1493,1105],{"class":1076},[202,1495,1497,1500,1502,1505,1507,1510],{"class":233,"line":1496},33,[202,1498,1499],{"class":246},"            \"-i\"",[202,1501,1077],{"class":1076},[202,1503,1504],{"class":1314}," str",[202,1506,1203],{"class":1076},[202,1508,1509],{"class":329},"path",[202,1511,1512],{"class":1076},"),\n",[202,1514,1516,1519],{"class":233,"line":1515},34,[202,1517,1518],{"class":246},"            \"--avhw\"",[202,1520,1105],{"class":1076},[202,1522,1524,1527,1529,1532],{"class":233,"line":1523},35,[202,1525,1526],{"class":246},"            \"-c\"",[202,1528,1077],{"class":1076},[202,1530,1531],{"class":246}," \"hevc\"",[202,1533,1105],{"class":1076},[202,1535,1537,1540,1542,1545],{"class":233,"line":1536},36,[202,1538,1539],{"class":246},"            \"--qvbr\"",[202,1541,1077],{"class":1076},[202,1543,1544],{"class":246}," \"24\"",[202,1546,1105],{"class":1076},[202,1548,1550,1553,1555,1558],{"class":233,"line":1549},37,[202,1551,1552],{"class":246},"            \"-u\"",[202,1554,1077],{"class":1076},[202,1556,1557],{"class":246}," \"P6\"",[202,1559,1105],{"class":1076},[202,1561,1563,1566,1568,1571],{"class":233,"line":1562},38,[202,1564,1565],{"class":246},"            \"--output-depth\"",[202,1567,1077],{"class":1076},[202,1569,1570],{"class":246}," \"10\"",[202,1572,1105],{"class":1076},[202,1574,1576,1579,1581,1584],{"class":233,"line":1575},39,[202,1577,1578],{"class":246},"            \"--lookahead\"",[202,1580,1077],{"class":1076},[202,1582,1583],{"class":246}," \"32\"",[202,1585,1105],{"class":1076},[202,1587,1589,1592,1594,1597,1599,1602,1604,1607],{"class":233,"line":1588},40,[202,1590,1591],{"class":246},"            \"-b\"",[202,1593,1077],{"class":1076},[202,1595,1596],{"class":246}," \"4\"",[202,1598,1077],{"class":1076},[202,1600,1601],{"class":246}," \"--bref-mode\"",[202,1603,1077],{"class":1076},[202,1605,1606],{"class":246}," \"each\"",[202,1608,1105],{"class":1076},[202,1610,1612,1615,1617,1620],{"class":233,"line":1611},41,[202,1613,1614],{"class":246},"            \"--aq\"",[202,1616,1077],{"class":1076},[202,1618,1619],{"class":246}," \"--aq-temporal\"",[202,1621,1105],{"class":1076},[202,1623,1625,1628,1630,1633],{"class":233,"line":1624},42,[202,1626,1627],{"class":246},"            \"--audio-codec\"",[202,1629,1077],{"class":1076},[202,1631,1632],{"class":246}," \"libopus\"",[202,1634,1105],{"class":1076},[202,1636,1638,1641,1643,1646],{"class":233,"line":1637},43,[202,1639,1640],{"class":246},"            \"--audio-bitrate\"",[202,1642,1077],{"class":1076},[202,1644,1645],{"class":246}," \"128\"",[202,1647,1105],{"class":1076},[202,1649,1651,1654,1656,1658,1660,1663],{"class":233,"line":1650},44,[202,1652,1653],{"class":246},"            \"-o\"",[202,1655,1077],{"class":1076},[202,1657,1504],{"class":1314},[202,1659,1203],{"class":1076},[202,1661,1662],{"class":329},"output_path",[202,1664,1214],{"class":1076},[202,1666,1668],{"class":233,"line":1667},45,[202,1669,1670],{"class":1076},"        ]\n",[202,1672,1674],{"class":233,"line":1673},46,[202,1675,1085],{"emptyLinePlaceholder":104},[202,1677,1679,1683,1685,1688,1690,1693,1695,1698,1700,1703],{"class":233,"line":1678},47,[202,1680,1682],{"class":1681},"snoqg","        print",[202,1684,1203],{"class":1076},[202,1686,1687],{"class":246},"\"Running\"",[202,1689,1077],{"class":1076},[202,1691,1692],{"class":246},"\" \"",[202,1694,1171],{"class":1076},[202,1696,1697],{"class":1174},"join",[202,1699,1203],{"class":1076},[202,1701,1702],{"class":329},"cmd",[202,1704,1705],{"class":1076},"))\n",[202,1707,1709,1712,1714,1717,1719,1722,1724,1726],{"class":233,"line":1708},48,[202,1710,1711],{"class":329},"        result ",[202,1713,1093],{"class":322},[202,1715,1716],{"class":329}," subprocess",[202,1718,1171],{"class":1076},[202,1720,1721],{"class":1174},"run",[202,1723,1203],{"class":1076},[202,1725,1702],{"class":329},[202,1727,1214],{"class":1076},[202,1729,1731,1733,1736,1738,1741,1744,1747],{"class":233,"line":1730},49,[202,1732,1401],{"class":1032},[202,1734,1735],{"class":329}," result",[202,1737,1171],{"class":1076},[202,1739,1740],{"class":329},"returncode ",[202,1742,1743],{"class":322},"!=",[202,1745,1746],{"class":339}," 0",[202,1748,1157],{"class":1076},[202,1750,1752,1755,1757,1761,1764,1768,1770,1772,1775,1778,1781],{"class":233,"line":1751},50,[202,1753,1754],{"class":1681},"            print",[202,1756,1203],{"class":1076},[202,1758,1760],{"class":1759},"sB-em","f",[202,1762,1763],{"class":246},"\"Failed: ",[202,1765,1767],{"class":1766},"s_ZFR","{",[202,1769,1509],{"class":329},[202,1771,1171],{"class":1076},[202,1773,1774],{"class":329},"name",[202,1776,1777],{"class":1766},"}",[202,1779,1780],{"class":246},"\"",[202,1782,1214],{"class":1076},[202,1784,1786],{"class":233,"line":1785},51,[202,1787,1420],{"class":1032},[202,1789,1791,1794,1797],{"class":233,"line":1790},52,[202,1792,1793],{"class":329},"        count ",[202,1795,1796],{"class":322},"+=",[202,1798,1799],{"class":339}," 1\n",[202,1801,1803,1805,1807,1809,1812,1814,1816,1818,1820,1822,1825,1827,1829,1831,1833],{"class":233,"line":1802},53,[202,1804,1682],{"class":1681},[202,1806,1203],{"class":1076},[202,1808,1760],{"class":1759},[202,1810,1811],{"class":246},"\"Done: ",[202,1813,1767],{"class":1766},[202,1815,1509],{"class":329},[202,1817,1171],{"class":1076},[202,1819,1774],{"class":329},[202,1821,1777],{"class":1766},[202,1823,1824],{"class":246}," -> ",[202,1826,1767],{"class":1766},[202,1828,1662],{"class":329},[202,1830,1777],{"class":1766},[202,1832,1780],{"class":246},[202,1834,1214],{"class":1076},[202,1836,1838],{"class":233,"line":1837},54,[202,1839,1085],{"emptyLinePlaceholder":104},[202,1841,1843,1845],{"class":233,"line":1842},55,[202,1844,1260],{"class":1032},[202,1846,1847],{"class":329}," count\n",[202,1849,1851],{"class":233,"line":1850},56,[202,1852,1085],{"emptyLinePlaceholder":104},[202,1854,1856,1858,1861,1863,1865,1867],{"class":233,"line":1855},57,[202,1857,1136],{"class":1032},[202,1859,1860],{"class":237}," main",[202,1862,1142],{"class":1076},[202,1864,1145],{"class":1076},[202,1866,1154],{"class":339},[202,1868,1157],{"class":1076},[202,1870,1872,1875,1877,1879],{"class":233,"line":1871},58,[202,1873,1874],{"class":329},"    input_dir ",[202,1876,1093],{"class":322},[202,1878,1139],{"class":1174},[202,1880,1178],{"class":1076},[202,1882,1884,1887,1889,1892,1894],{"class":233,"line":1883},59,[202,1885,1886],{"class":1032},"    if",[202,1888,1328],{"class":329},[202,1890,1891],{"class":1032},"is",[202,1893,1154],{"class":339},[202,1895,1157],{"class":1076},[202,1897,1899],{"class":233,"line":1898},60,[202,1900,1901],{"class":1032},"        return\n",[202,1903,1905],{"class":233,"line":1904},61,[202,1906,1085],{"emptyLinePlaceholder":104},[202,1908,1910,1912,1914,1916,1918,1921,1923,1926,1928,1930,1932,1935],{"class":233,"line":1909},62,[202,1911,1886],{"class":1032},[202,1913,1404],{"class":1032},[202,1915,1387],{"class":329},[202,1917,1171],{"class":1076},[202,1919,1920],{"class":1174},"exists",[202,1922,1142],{"class":1076},[202,1924,1925],{"class":1032}," or",[202,1927,1404],{"class":1032},[202,1929,1387],{"class":329},[202,1931,1171],{"class":1076},[202,1933,1934],{"class":1174},"is_dir",[202,1936,1395],{"class":1076},[202,1938,1940,1943,1945,1948,1950,1953,1955,1958],{"class":233,"line":1939},63,[202,1941,1942],{"class":329},"        messagebox",[202,1944,1171],{"class":1076},[202,1946,1947],{"class":1174},"showerror",[202,1949,1203],{"class":1076},[202,1951,1952],{"class":246},"\"エラー\"",[202,1954,1077],{"class":1076},[202,1956,1957],{"class":246}," \"有効なフォルダが選択されませんでした。\"",[202,1959,1214],{"class":1076},[202,1961,1963],{"class":233,"line":1962},64,[202,1964,1901],{"class":1032},[202,1966,1968],{"class":233,"line":1967},65,[202,1969,1085],{"emptyLinePlaceholder":104},[202,1971,1973,1976,1978,1980,1982,1984,1986,1988],{"class":233,"line":1972},66,[202,1974,1975],{"class":329},"    processed ",[202,1977,1093],{"class":322},[202,1979,1296],{"class":1174},[202,1981,1203],{"class":1076},[202,1983,1301],{"class":1234},[202,1985,1093],{"class":322},[202,1987,1301],{"class":329},[202,1989,1214],{"class":1076},[202,1991,1993,1996,1998,2001,2003,2006,2008,2010,2012,2014,2017,2019,2022],{"class":233,"line":1992},67,[202,1994,1995],{"class":329},"    messagebox",[202,1997,1171],{"class":1076},[202,1999,2000],{"class":1174},"showinfo",[202,2002,1203],{"class":1076},[202,2004,2005],{"class":246},"\"完了\"",[202,2007,1077],{"class":1076},[202,2009,1760],{"class":1759},[202,2011,1780],{"class":246},[202,2013,1767],{"class":1766},[202,2015,2016],{"class":329},"processed",[202,2018,1777],{"class":1766},[202,2020,2021],{"class":246},"個の動画を処理しました\"",[202,2023,1214],{"class":1076},[202,2025,2027],{"class":233,"line":2026},68,[202,2028,1085],{"emptyLinePlaceholder":104},[202,2030,2032,2035,2038,2041,2044],{"class":233,"line":2031},69,[202,2033,2034],{"class":1032},"if",[202,2036,2037],{"class":329}," __name__ ",[202,2039,2040],{"class":322},"==",[202,2042,2043],{"class":246}," \"__main__\"",[202,2045,1157],{"class":1076},[202,2047,2049,2052],{"class":233,"line":2048},70,[202,2050,2051],{"class":1174},"    main",[202,2053,1178],{"class":1076},[11,2055,2056],{"id":2056},"比較する",[36,2058,2060],{"id":2059},"vmaf","VMAF",[15,2062,2063,2064,2066],{},"FFMetricsというツールを使って入力ファイルとエンコードされたファイルの画質比較を行う。許容は95程度。",[19,2065],{},"\n05:00~07:00の2分間を比較しています。",[15,2068,2069],{},[195,2070],{"alt":89,"src":2071},"https:\u002F\u002Fimag.samenoko.work\u002Fuploads\u002F1775438628597-uxd7lj.png",[15,2073,2074],{},[195,2075],{"alt":89,"src":2076},"https:\u002F\u002Fimag.samenoko.work\u002Fuploads\u002F1775438695811-5657p3.png",[15,2078,2079],{},"結果は画像の通りで、97。90以上が高画質とされています。つまりそこそこということですね。",[36,2081,2082],{"id":2082},"ファイルサイズ",[15,2084,2085],{},"元データが1.34GB、ビットレートが8147kbpsで、出力ファイルが242MB、ビットレートが1433kbpsです。",[15,2087,2088],{},"大体8割削減されたことになります。ダイエット大成功！！",[11,2090,2091],{"id":2091},"おわり",[15,2093,2094,2095,2097],{},"現時点でかなりの設定を出せています。",[19,2096],{},"\nまぁ互換性とかライセンスの問題でHEVCとかAV1って再生できない環境も多いので、いい加減オープンでフリーな高効率なコーデックが出てほしいですね。",[15,2099,677],{},[679,2101,2102],{},"html pre.shiki code .siK8c, html code.shiki .siK8c{--shiki-default:#8AADF4;--shiki-default-font-style:italic}html pre.shiki code .sSZ1V, html code.shiki .sSZ1V{--shiki-default:#A6DA95}html pre.shiki code .s7Qn8, html code.shiki .s7Qn8{--shiki-default:#F5A97F}html .default .shiki span {color: var(--shiki-default);background: var(--shiki-default-bg);font-style: var(--shiki-default-font-style);font-weight: var(--shiki-default-font-weight);text-decoration: var(--shiki-default-text-decoration);}html .shiki span {color: var(--shiki-default);background: var(--shiki-default-bg);font-style: var(--shiki-default-font-style);font-weight: var(--shiki-default-font-weight);text-decoration: var(--shiki-default-text-decoration);}html pre.shiki code .sIF4r, html code.shiki .sIF4r{--shiki-default:#C6A0F6}html pre.shiki code .sFaBz, html code.shiki .sFaBz{--shiki-default:#CAD3F5}html pre.shiki code .slVFb, html code.shiki .slVFb{--shiki-default:#939AB7}html pre.shiki code .sXptk, html code.shiki .sXptk{--shiki-default:#8BD5CA}html pre.shiki code .s57MT, html code.shiki .s57MT{--shiki-default:#8AADF4}html pre.shiki code .skVQi, html code.shiki .skVQi{--shiki-default:#EE99A0;--shiki-default-font-style:italic}html pre.shiki code .srmJT, html code.shiki .srmJT{--shiki-default:#EE99A0}html pre.shiki code .sxfwU, html code.shiki .sxfwU{--shiki-default:#C6A0F6;--shiki-default-font-style:italic}html pre.shiki code .snoqg, html code.shiki .snoqg{--shiki-default:#F5A97F;--shiki-default-font-style:italic}html pre.shiki code .sB-em, html code.shiki .sB-em{--shiki-default:#A6DA95;--shiki-default-font-style:italic}html pre.shiki code .s_ZFR, html code.shiki .s_ZFR{--shiki-default:#F5BDE6}",{"title":89,"searchDepth":90,"depth":90,"links":2104},[2105,2106,2109,2116,2124,2128],{"id":711,"depth":90,"text":711},{"id":720,"depth":90,"text":720,"children":2107},[2108],{"id":723,"depth":96,"text":724},{"id":771,"depth":90,"text":771,"children":2110},[2111,2112,2113,2114,2115],{"id":823,"depth":96,"text":826},{"id":832,"depth":96,"text":835},{"id":844,"depth":96,"text":847},{"id":853,"depth":96,"text":856},{"id":865,"depth":96,"text":868},{"id":874,"depth":90,"text":874,"children":2117},[2118,2119,2120,2121,2122,2123],{"id":956,"depth":96,"text":959},{"id":968,"depth":96,"text":971},{"id":980,"depth":96,"text":983},{"id":989,"depth":96,"text":992},{"id":998,"depth":96,"text":1001},{"id":1007,"depth":96,"text":1010},{"id":2056,"depth":90,"text":2056,"children":2125},[2126,2127],{"id":2059,"depth":96,"text":2060},{"id":2082,"depth":96,"text":2082},{"id":2091,"depth":90,"text":2091},"2026-04-06","アニメエンコードの研究をしているログです。",{},"\u002Fblog\u002Fanime-encode-study",{"title":706,"description":2130},"blog\u002Fanime-encode-study",[2136,2137],{"name":110},{"name":2138},"エンコード","jWW2Tx7UfoXpBYmmvLTf2JAJFSTa3c-ZnWStr3zWmvo",{"id":2141,"title":2142,"body":2143,"date":2905,"description":2906,"extension":102,"meta":2907,"navigation":104,"path":2908,"seo":2909,"stem":2910,"tags":2911,"__hash__":2919},"blog\u002Fblog\u002Flibrechat-ollama-local-llm.md","LibreChat+OllamaでローカルLLM",{"type":8,"value":2144,"toc":2882},[2145,2149,2189,2192,2196,2235,2238,2241,2244,2312,2315,2318,2321,2344,2351,2354,2370,2373,2379,2382,2397,2400,2406,2408,2423,2426,2433,2438,2573,2578,2583,2724,2727,2730,2749,2756,2761,2764,2769,2772,2775,2778,2804,2807,2833,2838,2841,2844,2849,2854,2857,2859,2870,2873,2876,2879],[11,2146,2148],{"id":2147},"librechat","LibreChat",[157,2150,161,2152],{"className":2151},[160],[22,2153,171,2157,2182,161],{"href":2154,"target":165,"rel":2155,"className":2156},"https:\u002F\u002Fwww.librechat.ai\u002F",[167,168],[170],[157,2158,161,2160,161,2171],{"className":2159},[175],[157,2161,171,2163,171,2167,161],{"className":2162},[179],[157,2164,2166],{"className":2165},[183],"LibreChat - The Open-Source AI Platform",[157,2168,2170],{"className":2169},[188],"LibreChat brings together all your AI conversations in one unified, customizable interface.",[157,2172,171,2174,171,2178,161],{"className":2173},[193],[195,2175],{"src":2176,"className":2177,"width":200,"height":200,"alt":89},"https:\u002F\u002Fwww.librechat.ai\u002Ffavicon-32x32.png",[199],[202,2179,2181],{"className":2180},[205],"www.librechat.ai",[157,2183,161,2185],{"className":2184},[210],[195,2186],{"src":2187,"className":2188,"alt":89},"https:\u002F\u002Fwww.librechat.ai\u002Fimages\u002Fsocialcards\u002Fdefault-image.png",[215],[15,2190,2191],{},"ChatGPTみたいなUIを提供するやつです。",[11,2193,2195],{"id":2194},"ollama","Ollama",[157,2197,161,2199],{"className":2198},[160],[22,2200,171,2204,2228,161],{"href":2201,"target":165,"rel":2202,"className":2203},"https:\u002F\u002Follama.com\u002F",[167,168],[170],[157,2205,161,2207,161,2217],{"className":2206},[175],[157,2208,171,2210,171,2213,161],{"className":2209},[179],[157,2211,2195],{"className":2212},[183],[157,2214,2216],{"className":2215},[188],"Ollama is the easiest way to automate your work using open models, while keeping your data safe.",[157,2218,171,2220,171,2224,161],{"className":2219},[193],[195,2221],{"src":2222,"className":2223,"width":200,"height":200,"alt":89},"https:\u002F\u002Follama.com\u002Fpublic\u002Ficon-16x16.png",[199],[202,2225,2227],{"className":2226},[205],"ollama.com",[157,2229,161,2231],{"className":2230},[210],[195,2232],{"src":2233,"className":2234,"alt":89},"https:\u002F\u002Follama.com\u002Fpublic\u002Fog.png",[215],[15,2236,2237],{},"ローカルでLLMを動作させることのできるツールです。",[15,2239,2240],{},"以上の２つを合わせてローカルでAIを動作させていきたいっていう話。",[11,2242,2243],{"id":2243},"環境",[2245,2246,2247,2258],"table",{},[2248,2249,2250],"thead",{},[2251,2252,2253,2256],"tr",{},[2254,2255],"th",{},[2254,2257],{},[2259,2260,2261,2272,2282,2292,2302],"tbody",{},[2251,2262,2263,2267],{},[2264,2265,2266],"td",{},"CPU",[2264,2268,2269],{},[43,2270,2271],{},"Ryzen 7 5700X",[2251,2273,2274,2277],{},[2264,2275,2276],{},"RAM",[2264,2278,2279],{},[43,2280,2281],{},"32GB",[2251,2283,2284,2287],{},[2264,2285,2286],{},"SSD",[2264,2288,2289],{},[43,2290,2291],{},"1TB",[2251,2293,2294,2297],{},[2264,2295,2296],{},"GPU",[2264,2298,2299],{},[43,2300,2301],{},"NVIDIA RTX 4060 Ti 16GB",[2251,2303,2304,2307],{},[2264,2305,2306],{},"OS",[2264,2308,2309],{},[43,2310,2311],{},"ArchLinux",[15,2313,2314],{},"今回はDockerで動かしていきます。",[11,2316,2317],{"id":2317},"セットアップ",[36,2319,2320],{"id":2320},"リポジトリのクローン",[223,2322,2326],{"className":2323,"code":2324,"filename":771,"language":2325,"meta":89,"style":89},"language-bash shiki shiki-themes catppuccin-macchiato","git clone https:\u002F\u002Fgithub.com\u002Fdanny-avila\u002FLibreChat\ncd LibreChat\n","bash",[229,2327,2328,2337],{"__ignoreMap":89},[202,2329,2330,2332,2334],{"class":233,"line":234},[202,2331,435],{"class":237},[202,2333,438],{"class":246},[202,2335,2336],{"class":246}," https:\u002F\u002Fgithub.com\u002Fdanny-avila\u002FLibreChat\n",[202,2338,2339,2341],{"class":233,"line":90},[202,2340,447],{"class":446},[202,2342,2343],{"class":246}," LibreChat\n",[36,2345,2347,2350],{"id":2346},"envの作成",[229,2348,2349],{},".env","の作成",[15,2352,2353],{},"リポジトリ内にあるexampleをコピーする。",[223,2355,2357],{"className":2323,"code":2356,"filename":771,"language":2325,"meta":89,"style":89},"cp .env.example .env\n",[229,2358,2359],{"__ignoreMap":89},[202,2360,2361,2364,2367],{"class":233,"line":234},[202,2362,2363],{"class":237},"cp",[202,2365,2366],{"class":246}," .env.example",[202,2368,2369],{"class":246}," .env\n",[15,2371,2372],{},"内容は特にいじらなくていい。",[36,2374,2376,2350],{"id":2375},"librechatyamlの作成",[229,2377,2378],{},"librechat.yaml",[15,2380,2381],{},"これもリポジトリ内にあるexampleをコピーする。",[223,2383,2385],{"className":2323,"code":2384,"filename":771,"language":2325,"meta":89,"style":89},"cp librechat.example.yaml librechat.yaml\n",[229,2386,2387],{"__ignoreMap":89},[202,2388,2389,2391,2394],{"class":233,"line":234},[202,2390,2363],{"class":237},[202,2392,2393],{"class":246}," librechat.example.yaml",[202,2395,2396],{"class":246}," librechat.yaml\n",[15,2398,2399],{},"現時点では内容は編集しない。",[36,2401,2403,2350],{"id":2402},"docker-composeoverrideyamlの作成",[229,2404,2405],{},"docker-compose.override.yaml",[15,2407,2381],{},[223,2409,2411],{"className":2323,"code":2410,"filename":771,"language":2325,"meta":89,"style":89},"cp docker-compose.override.yml.example docker-compose.override.yml\n",[229,2412,2413],{"__ignoreMap":89},[202,2414,2415,2417,2420],{"class":233,"line":234},[202,2416,2363],{"class":237},[202,2418,2419],{"class":246}," docker-compose.override.yml.example",[202,2421,2422],{"class":246}," docker-compose.override.yml\n",[15,2424,2425],{},"これも現時点では内容を編集しない。",[36,2427,2429,2432],{"id":2428},"docker-composeoverrideymlの編集",[229,2430,2431],{},"docker-compose.override.yml","の編集",[15,2434,2435,2437],{},[229,2436,2378],{},"をマウントしたり、Ollamaを追加します。",[223,2439,2443],{"className":2440,"code":2441,"filename":2431,"language":2442,"meta":89,"style":89},"language-yaml shiki shiki-themes catppuccin-macchiato","services:\n    api:\n        volumes:\n            - type: bind\n              source: .\u002Flibrechat.yaml\n              target: \u002Fapp\u002Flibrechat.yaml\n    ollama:\n        image: ollama\u002Follama:latest\n        container_name: ollama\n        restart: unless-stopped\n        gpus: all\n        ports:\n            - \"11434:11434\"\n        volumes:\n            - .\u002Follama:\u002Froot\u002F.ollama\n","yaml",[229,2444,2445,2452,2459,2466,2479,2489,2499,2506,2516,2526,2536,2546,2553,2560,2566],{"__ignoreMap":89},[202,2446,2447,2450],{"class":233,"line":234},[202,2448,2449],{"class":1174},"services",[202,2451,1157],{"class":322},[202,2453,2454,2457],{"class":233,"line":90},[202,2455,2456],{"class":1174},"    api",[202,2458,1157],{"class":322},[202,2460,2461,2464],{"class":233,"line":96},[202,2462,2463],{"class":1174},"        volumes",[202,2465,1157],{"class":322},[202,2467,2468,2471,2474,2476],{"class":233,"line":285},[202,2469,2470],{"class":1076},"            -",[202,2472,2473],{"class":1174}," type",[202,2475,1304],{"class":322},[202,2477,2478],{"class":246}," bind\n",[202,2480,2481,2484,2486],{"class":233,"line":291},[202,2482,2483],{"class":1174},"              source",[202,2485,1304],{"class":322},[202,2487,2488],{"class":246}," .\u002Flibrechat.yaml\n",[202,2490,2491,2494,2496],{"class":233,"line":297},[202,2492,2493],{"class":1174},"              target",[202,2495,1304],{"class":322},[202,2497,2498],{"class":246}," \u002Fapp\u002Flibrechat.yaml\n",[202,2500,2501,2504],{"class":233,"line":1099},[202,2502,2503],{"class":1174},"    ollama",[202,2505,1157],{"class":322},[202,2507,2508,2511,2513],{"class":233,"line":1108},[202,2509,2510],{"class":1174},"        image",[202,2512,1304],{"class":322},[202,2514,2515],{"class":246}," ollama\u002Follama:latest\n",[202,2517,2518,2521,2523],{"class":233,"line":1116},[202,2519,2520],{"class":1174},"        container_name",[202,2522,1304],{"class":322},[202,2524,2525],{"class":246}," ollama\n",[202,2527,2528,2531,2533],{"class":233,"line":1122},[202,2529,2530],{"class":1174},"        restart",[202,2532,1304],{"class":322},[202,2534,2535],{"class":246}," unless-stopped\n",[202,2537,2538,2541,2543],{"class":233,"line":1128},[202,2539,2540],{"class":1174},"        gpus",[202,2542,1304],{"class":322},[202,2544,2545],{"class":246}," all\n",[202,2547,2548,2551],{"class":233,"line":1133},[202,2549,2550],{"class":1174},"        ports",[202,2552,1157],{"class":322},[202,2554,2555,2557],{"class":233,"line":1160},[202,2556,2470],{"class":1076},[202,2558,2559],{"class":246}," \"11434:11434\"\n",[202,2561,2562,2564],{"class":233,"line":200},[202,2563,2463],{"class":1174},[202,2565,1157],{"class":322},[202,2567,2568,2570],{"class":233,"line":1193},[202,2569,2470],{"class":1076},[202,2571,2572],{"class":246}," .\u002Follama:\u002Froot\u002F.ollama\n",[36,2574,2576,2432],{"id":2575},"librechatyamlの編集",[229,2577,2378],{},[15,2579,2580,2582],{},[229,2581,2195],{},"を使うように設定します。",[223,2584,2586],{"className":2440,"code":2585,"filename":2378,"language":2442,"meta":89,"style":89},"version: 1.3.6\nendpoints:\n  custom:\n    - name: \"Ollama\"\n      apiKey: \"ollama\"\n      baseURL: \"http:\u002F\u002Follama:11434\u002Fv1\u002F\"\n      models:\n        default:\n          - \"qwen3.5\"\n        fetch: true\n      titleConvo: true\n      titleModel: \"current_model\"\n      summarize: false\n      summaryModel: \"current_model\"\n      modelDisplayLabel: \"Ollama\"\n",[229,2587,2588,2598,2605,2612,2625,2635,2645,2652,2659,2667,2677,2686,2696,2706,2715],{"__ignoreMap":89},[202,2589,2590,2593,2595],{"class":233,"line":234},[202,2591,2592],{"class":1174},"version",[202,2594,1304],{"class":322},[202,2596,2597],{"class":339}," 1.3.6\n",[202,2599,2600,2603],{"class":233,"line":90},[202,2601,2602],{"class":1174},"endpoints",[202,2604,1157],{"class":322},[202,2606,2607,2610],{"class":233,"line":96},[202,2608,2609],{"class":1174},"  custom",[202,2611,1157],{"class":322},[202,2613,2614,2617,2620,2622],{"class":233,"line":285},[202,2615,2616],{"class":1076},"    -",[202,2618,2619],{"class":1174}," name",[202,2621,1304],{"class":322},[202,2623,2624],{"class":246}," \"Ollama\"\n",[202,2626,2627,2630,2632],{"class":233,"line":291},[202,2628,2629],{"class":1174},"      apiKey",[202,2631,1304],{"class":322},[202,2633,2634],{"class":246}," \"ollama\"\n",[202,2636,2637,2640,2642],{"class":233,"line":297},[202,2638,2639],{"class":1174},"      baseURL",[202,2641,1304],{"class":322},[202,2643,2644],{"class":246}," \"http:\u002F\u002Follama:11434\u002Fv1\u002F\"\n",[202,2646,2647,2650],{"class":233,"line":1099},[202,2648,2649],{"class":1174},"      models",[202,2651,1157],{"class":322},[202,2653,2654,2657],{"class":233,"line":1108},[202,2655,2656],{"class":1174},"        default",[202,2658,1157],{"class":322},[202,2660,2661,2664],{"class":233,"line":1116},[202,2662,2663],{"class":1076},"          -",[202,2665,2666],{"class":246}," \"qwen3.5\"\n",[202,2668,2669,2672,2674],{"class":233,"line":1122},[202,2670,2671],{"class":1174},"        fetch",[202,2673,1304],{"class":322},[202,2675,2676],{"class":339}," true\n",[202,2678,2679,2682,2684],{"class":233,"line":1128},[202,2680,2681],{"class":1174},"      titleConvo",[202,2683,1304],{"class":322},[202,2685,2676],{"class":339},[202,2687,2688,2691,2693],{"class":233,"line":1133},[202,2689,2690],{"class":1174},"      titleModel",[202,2692,1304],{"class":322},[202,2694,2695],{"class":246}," \"current_model\"\n",[202,2697,2698,2701,2703],{"class":233,"line":1160},[202,2699,2700],{"class":1174},"      summarize",[202,2702,1304],{"class":322},[202,2704,2705],{"class":339}," false\n",[202,2707,2708,2711,2713],{"class":233,"line":200},[202,2709,2710],{"class":1174},"      summaryModel",[202,2712,1304],{"class":322},[202,2714,2695],{"class":246},[202,2716,2717,2720,2722],{"class":233,"line":1193},[202,2718,2719],{"class":1174},"      modelDisplayLabel",[202,2721,1304],{"class":322},[202,2723,2624],{"class":246},[11,2725,2726],{"id":2726},"起動",[15,2728,2729],{},"ここまで設定を進めたら起動します。",[223,2731,2733],{"className":2323,"code":2732,"filename":771,"language":2325,"meta":89,"style":89},"docker compose up -d\n",[229,2734,2735],{"__ignoreMap":89},[202,2736,2737,2740,2743,2746],{"class":233,"line":234},[202,2738,2739],{"class":237},"docker",[202,2741,2742],{"class":246}," compose",[202,2744,2745],{"class":246}," up",[202,2747,2748],{"class":246}," -d\n",[15,2750,2751,2752,2755],{},"ブラウザから",[229,2753,2754],{},"http:\u002F\u002Flocalhost:3080","にアクセスすると、",[15,2757,2758],{},[195,2759],{"alt":89,"src":2760},"https:\u002F\u002Fstorage.googleapis.com\u002Fzenn-user-upload\u002F8f931ac8ea08-20260323.png",[15,2762,2763],{},"こんな感じの画面が現れます。Sign upしてください。",[15,2765,2766],{},[195,2767],{"alt":89,"src":2768},"https:\u002F\u002Fstorage.googleapis.com\u002Fzenn-user-upload\u002F20c286e091ec-20260323.png",[15,2770,2771],{},"ログインすると、こんな感じ。",[11,2773,2774],{"id":2774},"ollamaのモデルをpull",[15,2776,2777],{},"ollamaでモデルをpullします。今回はqwen3.5を。",[223,2779,2781],{"className":2323,"code":2780,"filename":771,"language":2325,"meta":89,"style":89},"docker exec -it ollama ollama pull qwen3.5\n",[229,2782,2783],{"__ignoreMap":89},[202,2784,2785,2787,2790,2793,2796,2798,2801],{"class":233,"line":234},[202,2786,2739],{"class":237},[202,2788,2789],{"class":246}," exec",[202,2791,2792],{"class":246}," -it",[202,2794,2795],{"class":246}," ollama",[202,2797,2795],{"class":246},[202,2799,2800],{"class":246}," pull",[202,2802,2803],{"class":246}," qwen3.5\n",[15,2805,2806],{},"モデルをpullしたら再起動します。",[223,2808,2810],{"className":2323,"code":2809,"filename":771,"language":2325,"meta":89,"style":89},"docker compose down && docker compose up -d\n",[229,2811,2812],{"__ignoreMap":89},[202,2813,2814,2816,2818,2821,2824,2827,2829,2831],{"class":233,"line":234},[202,2815,2739],{"class":237},[202,2817,2742],{"class":246},[202,2819,2820],{"class":246}," down",[202,2822,2823],{"class":1076}," &&",[202,2825,2826],{"class":237}," docker",[202,2828,2742],{"class":246},[202,2830,2745],{"class":246},[202,2832,2748],{"class":246},[15,2834,2835],{},[195,2836],{"alt":89,"src":2837},"https:\u002F\u002Fstorage.googleapis.com\u002Fzenn-user-upload\u002Fc96a9aae3047-20260323.png",[15,2839,2840],{},"モデルの選択画面に現れればOKです。",[11,2842,2843],{"id":2843},"話してみる",[15,2845,2846],{},[195,2847],{"alt":89,"src":2848},"https:\u002F\u002Fstorage.googleapis.com\u002Fzenn-user-upload\u002Fedebedca3cea-20260323.png",[15,2850,2851],{},[195,2852],{"alt":89,"src":2853},"https:\u002F\u002Fstorage.googleapis.com\u002Fzenn-user-upload\u002F39083ef68b05-20260323.png",[15,2855,2856],{},"ちゃんと話せます。",[11,2858,2091],{"id":2091},[15,2860,2861,2862,2864,2865,2867],{},"今回はここまでです。",[19,2863],{},"\nここでは書いていませんが検索まで設定してます。",[19,2866],{},[195,2868],{"alt":89,"src":2869},"https:\u002F\u002Fstorage.googleapis.com\u002Fzenn-user-upload\u002F6e5888869252-20260323.png",[15,2871,2872],{},"いいぽよ。",[11,2874,2875],{"id":2875},"更新履歴",[15,2877,2878],{},"2026\u002F03\u002F24: 一部内容に誤りがあったため修正",[679,2880,2881],{},"html pre.shiki code .siK8c, html code.shiki .siK8c{--shiki-default:#8AADF4;--shiki-default-font-style:italic}html pre.shiki code .sSZ1V, html code.shiki .sSZ1V{--shiki-default:#A6DA95}html pre.shiki code .sizsb, html code.shiki .sizsb{--shiki-default:#ED8796;--shiki-default-font-style:italic}html .default .shiki span {color: var(--shiki-default);background: var(--shiki-default-bg);font-style: var(--shiki-default-font-style);font-weight: var(--shiki-default-font-weight);text-decoration: var(--shiki-default-text-decoration);}html .shiki span {color: var(--shiki-default);background: var(--shiki-default-bg);font-style: var(--shiki-default-font-style);font-weight: var(--shiki-default-font-weight);text-decoration: var(--shiki-default-text-decoration);}html pre.shiki code .s57MT, html code.shiki .s57MT{--shiki-default:#8AADF4}html pre.shiki code .sXptk, html code.shiki .sXptk{--shiki-default:#8BD5CA}html pre.shiki code .slVFb, html code.shiki .slVFb{--shiki-default:#939AB7}html pre.shiki code .s7Qn8, html code.shiki .s7Qn8{--shiki-default:#F5A97F}",{"title":89,"searchDepth":90,"depth":90,"links":2883},[2884,2885,2886,2887,2900,2901,2902,2903,2904],{"id":2147,"depth":90,"text":2148},{"id":2194,"depth":90,"text":2195},{"id":2243,"depth":90,"text":2243},{"id":2317,"depth":90,"text":2317,"children":2888},[2889,2890,2892,2894,2896,2898],{"id":2320,"depth":96,"text":2320},{"id":2346,"depth":96,"text":2891},".envの作成",{"id":2375,"depth":96,"text":2893},"librechat.yamlの作成",{"id":2402,"depth":96,"text":2895},"docker-compose.override.yamlの作成",{"id":2428,"depth":96,"text":2897},"docker-compose.override.ymlの編集",{"id":2575,"depth":96,"text":2899},"librechat.yamlの編集",{"id":2726,"depth":90,"text":2726},{"id":2774,"depth":90,"text":2774},{"id":2843,"depth":90,"text":2843},{"id":2091,"depth":90,"text":2091},{"id":2875,"depth":90,"text":2875},"2026-03-23","LibreChatとOllamaを組み合わせて、ローカル環境で大規模言語モデル（LLM）を動作させる方法を解説します。",{},"\u002Fblog\u002Flibrechat-ollama-local-llm",{"title":2142,"description":2906},"blog\u002Flibrechat-ollama-local-llm",[2912,2914,2915,2917],{"name":2913},"ai",{"name":2739},{"name":2916},"llm",{"name":2918},"ローカルllm","70Y3GKjsJwqYS1z54qt9P2ozne14EEXcnMqOyjquMfI",{"id":2921,"title":2922,"body":2923,"date":3816,"description":3817,"extension":102,"meta":3818,"navigation":104,"path":3819,"seo":3820,"stem":3821,"tags":3822,"__hash__":3828},"blog\u002Fblog\u002Fcloudflare-zero-trust-home-access.md","Cloudflare Zero Trustで宅外から宅内のネットワークへアクセスする",{"type":8,"value":2924,"toc":3802},[2925,2929,2932,2965,2971,2974,2977,2984,2987,3009,3012,3016,3033,3157,3160,3228,3231,3270,3274,3280,3283,3299,3351,3368,3446,3449,3523,3526,3544,3552,3555,3599,3602,3608,3615,3639,3642,3707,3711,3718,3764,3767,3782,3785,3791,3793,3799],[11,2926,2928],{"id":2927},"cloudflare-zero-trust","Cloudflare Zero Trust",[15,2930,2931],{},"Cloudflareが提供するZero Trustセキュリティモデルに基づいた包括的ネットワークセキュリティプラットフォームらしいです。",[157,2933,161,2935],{"className":2934},[160],[22,2936,171,2940,161],{"href":2937,"target":165,"rel":2938,"className":2939},"https:\u002F\u002Fwww.cloudflare.com\u002Fja-jp\u002Fzero-trust\u002F",[167,168],[170],[157,2941,161,2943,161,2954],{"className":2942},[175],[157,2944,171,2946,171,2950,161],{"className":2945},[179],[157,2947,2949],{"className":2948},[183],"Cloudflare One | 俊敏で真に統合されたSASEプラットフォーム",[157,2951,2953],{"className":2952},[188],"「統合SASEプラットフォーム」の約束が実現。安全なAI導入への近道を進みましょう。従業員、AIエージェント、インフラストラクチャをつなぎ、保護します。",[157,2955,171,2957,171,2961,161],{"className":2956},[193],[195,2958],{"src":2959,"className":2960,"width":200,"height":200,"alt":89},"https:\u002F\u002Fwww.cloudflare.com\u002Ffavicon.ico",[199],[202,2962,2964],{"className":2963},[205],"www.cloudflare.com",[15,2966,2967,2968,2970],{},"らしいんですが今回の目的はセキュリティよりも便利のほうが重要なので、ここらへんのすごさには触れません。",[19,2969],{},"\nｽﾝﾏｾﾝ。",[11,2972,2973],{"id":2973},"なにがしたいか",[15,2975,2976],{},"外にいるときに家の中のネットーワークにアクセスしたい。これだけです。",[15,2978,2979,2980,2983],{},"旅館やカフェ(田舎にはそんなものは無いが)などから",[229,2981,2982],{},"192.168.0.40","で接続できるようにしたい…って感じ。",[11,2985,2986],{"id":2986},"アカウントのセットアップなど",[15,2988,2989,2990,2992,2997,2998,3000,3003,3005,3006,3008],{},"ここでは詳細に説明しません。っていうか使い始めたのが2年前とかなり前なので、覚えていません。",[19,2991],{},[22,2993,2996],{"href":2994,"rel":2995},"https:\u002F\u002Fdash.cloudflare.com",[26],"Cloudflareの管理画面","のサイドバーに",[19,2999],{},[195,3001],{"alt":89,"src":3002},"https:\u002F\u002Fstorage.googleapis.com\u002Fzenn-user-upload\u002Fb951970562bd-20251222.png",[19,3004],{},"\nZero Trustという項目があるのでそこをクリックして案内に従ってください。",[19,3007],{},"\n設定した当時とかなりUIが変わっていて説明できません。すみません。",[15,3010,3011],{},"おそらくチーム名を決めると思うのですが、それを控えておきましょう。",[11,3013,3015],{"id":3014},"idプロバイダーを追加する","IDプロバイダーを追加する",[15,3017,3018,3019,3021,3022,3024,3027,3029,3030,3032],{},"デフォルトでメールアドレスを使用したワンタイムコードを利用可能です。しかしこれは不便なのでGoogleアカウントとかでログインできると便利だよね。",[19,3020],{},"\nってことで追加しましょう。",[19,3023],{},[195,3025],{"alt":89,"src":3026},"https:\u002F\u002Fstorage.googleapis.com\u002Fzenn-user-upload\u002Fb7b33758a7af-20251222.png",[19,3028],{},"\nZero Trustのサイドバーの「インテグレーション」の「IDプロバイダー」を開きます。",[19,3031],{},"\n画像では既にGoogleが追加されていますが気にしないでいいです。",[15,3034,3035,3038,3040,3041,3043,3046,3048,3049,3051,3054,3056,3057,3059,3060,3062,3063,3068,3069,3071,3074,3076,3077,3079,3082,3084,3085,3087,3090,3092,3093,3095,3098,3100,3101,3103,3106,3108,3109,3112,3113,3116,3117,3119,3122,3124,3125,3127,3130,3132,3133,3135,3138,3140,3141,3143,3146,3148,3149,3151,3154,3156],{},[195,3036],{"alt":89,"src":3037},"https:\u002F\u002Fstorage.googleapis.com\u002Fzenn-user-upload\u002Fd8e30a80fa89-20251222.png",[19,3039],{},"\nまずは「IDプロバイダーを追加する」をクリックし、",[19,3042],{},[195,3044],{"alt":89,"src":3045},"https:\u002F\u002Fstorage.googleapis.com\u002Fzenn-user-upload\u002F79f49984abf1-20251222.png",[19,3047],{},"\n「Google」を選択する。",[19,3050],{},[195,3052],{"alt":89,"src":3053},"https:\u002F\u002Fstorage.googleapis.com\u002Fzenn-user-upload\u002F57a89fac6dff-20251222.png",[19,3055],{},"\n選択すると画像のような画面に変わります。右側に手順が載っております。英語ですけど。",[19,3058],{},"\n名前は分かりやすいもの(例:Google)にします。",[19,3061],{},"\n続いて",[22,3064,3067],{"href":3065,"rel":3066},"https:\u002F\u002Fconsole.cloud.google.com\u002F",[26],"Google Cloud Console","にアクセスし、",[19,3070],{},[195,3072],{"alt":89,"src":3073},"https:\u002F\u002Fstorage.googleapis.com\u002Fzenn-user-upload\u002Fe0e14d9a8363-20251222.png",[19,3075],{},"\n「APIとサービス」を開き、",[19,3078],{},[195,3080],{"alt":89,"src":3081},"https:\u002F\u002Fstorage.googleapis.com\u002Fzenn-user-upload\u002F82c2234a065b-20251222.png",[19,3083],{},"\n「OAuth同意画面」を開きます。",[19,3086],{},[195,3088],{"alt":89,"src":3089},"https:\u002F\u002Fstorage.googleapis.com\u002Fzenn-user-upload\u002F8815353d613b-20251222.png",[19,3091],{},"\n「クライアント」を選択し、「クライアントを作成」をクリックします。",[19,3094],{},[195,3096],{"alt":89,"src":3097},"https:\u002F\u002Fstorage.googleapis.com\u002Fzenn-user-upload\u002Fb9601643ad31-20251222.png",[19,3099],{},"\nアプリケーションの種類は「ウェブアプリケーション」、名前は適切なものを入力します。",[19,3102],{},[195,3104],{"alt":89,"src":3105},"https:\u002F\u002Fstorage.googleapis.com\u002Fzenn-user-upload\u002Fb858aae10ee6-20251222.png",[19,3107],{},"\n承認済みのJavaScript生成元には",[229,3110,3111],{},"https:\u002F\u002F\u003C設定したチーム名>.cloudflareaccess.com","を、承認済みのリダイレクトURIには",[229,3114,3115],{},"https:\u002F\u002F\u003C設定したチーム名>.cloudflareaccess.com\u002Fcdn-cgi\u002Faccess\u002Fcallback","を設定します。",[19,3118],{},[195,3120],{"alt":89,"src":3121},"https:\u002F\u002Fstorage.googleapis.com\u002Fzenn-user-upload\u002Fff5525003e55-20251222.png",[19,3123],{},"\nあとは「作成」をクリックします。",[19,3126],{},[195,3128],{"alt":89,"src":3129},"https:\u002F\u002Fstorage.googleapis.com\u002Fzenn-user-upload\u002F1d4485a28781-20251222.png",[19,3131],{},"\nすると「クライアントID」と「クライアントシークレット」が表示されるので、",[19,3134],{},[195,3136],{"alt":89,"src":3137},"https:\u002F\u002Fstorage.googleapis.com\u002Fzenn-user-upload\u002F785e31de043c-20251222.png",[19,3139],{},"\nCloudflare側の入力欄にそれぞれコピペする。あとは保存するだけです。",[19,3142],{},[195,3144],{"alt":89,"src":3145},"https:\u002F\u002Fstorage.googleapis.com\u002Fzenn-user-upload\u002F26db95831097-20251222.png",[19,3147],{},"\nIDプロバイダー一覧の画面で先程作成したプロバイダーの欄にある「テスト」をクリックしてみて",[19,3150],{},[195,3152],{"alt":89,"src":3153},"https:\u002F\u002Fstorage.googleapis.com\u002Fzenn-user-upload\u002F4c85c58b7376-20251222.png",[19,3155],{},"\n画像のようにログイン中のGoogleアカウントの情報が表示されるか、Googleアカウントの選択画面が現れれば大丈夫です。",[11,3158,3159],{"id":3159},"トンネルの追加",[15,3161,3162,3165,3167,3168,3170,3173,3175,3176,3178,3181,3183,3184,3186,3189,3191,3192,3195,3196,3198,3201,3203,3204,3206,3209,3211,3212,3214,3217,3219,3220,3222,3225,3227],{},[195,3163],{"alt":89,"src":3164},"https:\u002F\u002Fstorage.googleapis.com\u002Fzenn-user-upload\u002F2852721d005f-20251222.png",[19,3166],{},"\nサイドバーの「ネットワーク」から「コネクタ」を開き、「トンネルを作成する」をクリックする。",[19,3169],{},[195,3171],{"alt":89,"src":3172},"https:\u002F\u002Fstorage.googleapis.com\u002Fzenn-user-upload\u002F0d610b62e1ae-20251222.png",[19,3174],{},"\nトンネルの種類は「Cloudflared」にする。",[19,3177],{},[195,3179],{"alt":89,"src":3180},"https:\u002F\u002Fstorage.googleapis.com\u002Fzenn-user-upload\u002Fe48ae318a8aa-20251222.png",[19,3182],{},"\nトンネル名は適当なものを付けます。私は「myhome」と。ひねりもねぇ。",[19,3185],{},[195,3187],{"alt":89,"src":3188},"https:\u002F\u002Fstorage.googleapis.com\u002Fzenn-user-upload\u002F20009a0d1000-20251222.png",[19,3190],{},"\n次はコネクタのインストールです。お使いのサーバーのOSとアーキテクチャを選択して、表示されるコマンドを実行して",[229,3193,3194],{},"cloudflared","をインストールします。",[19,3197],{},[195,3199],{"alt":89,"src":3200},"https:\u002F\u002Fstorage.googleapis.com\u002Fzenn-user-upload\u002F768d47457583-20251222.png",[19,3202],{},"\nインストールが終わったら画像の欄にあるコマンドを実行してコネクタを接続します。",[19,3205],{},[195,3207],{"alt":89,"src":3208},"https:\u002F\u002Fstorage.googleapis.com\u002Fzenn-user-upload\u002Feb9ad3b579f2-20251222.png",[19,3210],{},"\n接続が成功したら「Connectors」に何かが表示されるはずです。",[19,3213],{},[195,3215],{"alt":89,"src":3216},"https:\u002F\u002Fstorage.googleapis.com\u002Fzenn-user-upload\u002Fca5c51894b91-20251222.png",[19,3218],{},"\n「トラフィックのルーティング」という画面が表示されると思いますがこの画面はスキップしていいです。サイドバーの「ネットワーク」→「コネクタ」をクリックすると戻れます。",[19,3221],{},[195,3223],{"alt":89,"src":3224},"https:\u002F\u002Fstorage.googleapis.com\u002Fzenn-user-upload\u002F4f6b79653e5b-20251222.png",[19,3226],{},"\n作成したコネクタが表示されてステータスが緑であればOKです。",[11,3229,3230],{"id":3230},"ルートを設定",[15,3232,3233,3236,3238,3239,3241,3244,3246,3247,3249,3252,3254,3255,3258,3259,46,3262,3264,3267,3269],{},[195,3234],{"alt":89,"src":3235},"https:\u002F\u002Fstorage.googleapis.com\u002Fzenn-user-upload\u002F9d3c1b0b3062-20251222.png",[19,3237],{},"\nさっき作成したコネクタの三点リーダーをクリックし「設定」を開きます。",[19,3240],{},[195,3242],{"alt":89,"src":3243},"https:\u002F\u002Fstorage.googleapis.com\u002Fzenn-user-upload\u002Fc56570432cce-20251222.png",[19,3245],{},"\n「CIDR」タブに移動し、「CIDRルートを追加」をクリックします。",[19,3248],{},[195,3250],{"alt":89,"src":3251},"https:\u002F\u002Fstorage.googleapis.com\u002Fzenn-user-upload\u002F955a81a7c3ff-20251222.png",[19,3253],{},"\nCIDRと説明を適当に入力します。私の家は",[229,3256,3257],{},"192.168.0.xx","なので",[229,3260,3261],{},"192.168.0.0\u002F24",[19,3263],{},[195,3265],{"alt":89,"src":3266},"https:\u002F\u002Fstorage.googleapis.com\u002Fzenn-user-upload\u002Fd5f3496f581e-20251222.png",[19,3268],{},"\nCIDRの画面に表示されればOK!",[11,3271,3273],{"id":3272},"管理ネットワークの作成","「管理ネットワーク」の作成",[15,3275,3276,3277,3279],{},"家の中にいるか、外に居るかを判断するためにビーコンみたいなサーバーを立てます。",[19,3278],{},"\nラズパイとか自宅サーバーで大丈夫です。TLSエンドポイントが必要だそうです。",[15,3281,3282],{},"今回はDockerで立ててみます。Dockerでなくても大丈夫ですが。",[15,3284,3285,3286,3289,3290,3293,3294,3296,3298],{},"適当なディレクトリを作成し、その中に",[229,3287,3288],{},"certs","ディレクトリと",[229,3291,3292],{},"nginx.conf","を作成します。",[19,3295],{},[229,3297,3288],{},"ディレクトリに自己TLS証明書を作成します。",[223,3300,3302],{"className":2323,"code":3301,"language":2325,"meta":89,"style":89},"openssl req -x509 -newkey rsa:4096 -sha256 -days 3650 -nodes -keyout privkey.pem -out fullchain.pem -subj \"\u002FCN=Generic SSL Certificate\"\n",[229,3303,3304],{"__ignoreMap":89},[202,3305,3306,3309,3312,3315,3318,3321,3324,3327,3330,3333,3336,3339,3342,3345,3348],{"class":233,"line":234},[202,3307,3308],{"class":237},"openssl",[202,3310,3311],{"class":246}," req",[202,3313,3314],{"class":246}," -x509",[202,3316,3317],{"class":246}," -newkey",[202,3319,3320],{"class":246}," rsa:4096",[202,3322,3323],{"class":246}," -sha256",[202,3325,3326],{"class":246}," -days",[202,3328,3329],{"class":339}," 3650",[202,3331,3332],{"class":246}," -nodes",[202,3334,3335],{"class":246}," -keyout",[202,3337,3338],{"class":246}," privkey.pem",[202,3340,3341],{"class":246}," -out",[202,3343,3344],{"class":246}," fullchain.pem",[202,3346,3347],{"class":246}," -subj",[202,3349,3350],{"class":246}," \"\u002FCN=Generic SSL Certificate\"\n",[15,3352,3353,3354,3356,3359,3361,3362,3364,3365,3367],{},"で作成可能です。",[19,3355],{},[195,3357],{"alt":89,"src":3358},"https:\u002F\u002Fstorage.googleapis.com\u002Fzenn-user-upload\u002Fc1265ed68131-20251222.png",[19,3360],{},"\n作成できました。",[19,3363],{},"\n次に",[229,3366,3292],{},"を書きます。次のように。",[223,3369,3373],{"className":3370,"code":3371,"filename":3292,"language":3372,"meta":89,"style":89},"language-nginx shiki shiki-themes catppuccin-macchiato","events {\n    worker_connections 1024;\n}\n\nhttp {\n    server {\n        listen 443 ssl;\n        ssl_certificate \u002Fcerts\u002Ffullchain.pem;\n        ssl_certificate_key \u002Fcerts\u002Fprivkey.pem;\n\n        location \u002F {\n                return 200;\n            }\n    }\n}\n","nginx",[229,3374,3375,3380,3385,3389,3393,3398,3403,3408,3413,3418,3422,3427,3432,3437,3442],{"__ignoreMap":89},[202,3376,3377],{"class":233,"line":234},[202,3378,3379],{},"events {\n",[202,3381,3382],{"class":233,"line":90},[202,3383,3384],{},"    worker_connections 1024;\n",[202,3386,3387],{"class":233,"line":96},[202,3388,1125],{},[202,3390,3391],{"class":233,"line":285},[202,3392,1085],{"emptyLinePlaceholder":104},[202,3394,3395],{"class":233,"line":291},[202,3396,3397],{},"http {\n",[202,3399,3400],{"class":233,"line":297},[202,3401,3402],{},"    server {\n",[202,3404,3405],{"class":233,"line":1099},[202,3406,3407],{},"        listen 443 ssl;\n",[202,3409,3410],{"class":233,"line":1108},[202,3411,3412],{},"        ssl_certificate \u002Fcerts\u002Ffullchain.pem;\n",[202,3414,3415],{"class":233,"line":1116},[202,3416,3417],{},"        ssl_certificate_key \u002Fcerts\u002Fprivkey.pem;\n",[202,3419,3420],{"class":233,"line":1122},[202,3421,1085],{"emptyLinePlaceholder":104},[202,3423,3424],{"class":233,"line":1128},[202,3425,3426],{},"        location \u002F {\n",[202,3428,3429],{"class":233,"line":1133},[202,3430,3431],{},"                return 200;\n",[202,3433,3434],{"class":233,"line":1160},[202,3435,3436],{},"            }\n",[202,3438,3439],{"class":233,"line":200},[202,3440,3441],{},"    }\n",[202,3443,3444],{"class":233,"line":1193},[202,3445,1125],{},[15,3447,3448],{},"あとはDocker Composeのファイルを書きます。",[223,3450,3453],{"className":2440,"code":3451,"filename":3452,"language":2442,"meta":89,"style":89},"services:\n  nginx:\n    restart: unless-stopped\n    image: nginx:latest\n    ports:\n      - 7676:443\n    volumes:\n      - .\u002Fnginx.conf:\u002Fetc\u002Fnginx\u002Fnginx.conf:ro\n      - .\u002Fcerts:\u002Fcerts:ro\n","compose.yml",[229,3454,3455,3461,3468,3477,3487,3494,3502,3509,3516],{"__ignoreMap":89},[202,3456,3457,3459],{"class":233,"line":234},[202,3458,2449],{"class":1174},[202,3460,1157],{"class":322},[202,3462,3463,3466],{"class":233,"line":90},[202,3464,3465],{"class":1174},"  nginx",[202,3467,1157],{"class":322},[202,3469,3470,3473,3475],{"class":233,"line":96},[202,3471,3472],{"class":1174},"    restart",[202,3474,1304],{"class":322},[202,3476,2535],{"class":246},[202,3478,3479,3482,3484],{"class":233,"line":285},[202,3480,3481],{"class":1174},"    image",[202,3483,1304],{"class":322},[202,3485,3486],{"class":246}," nginx:latest\n",[202,3488,3489,3492],{"class":233,"line":291},[202,3490,3491],{"class":1174},"    ports",[202,3493,1157],{"class":322},[202,3495,3496,3499],{"class":233,"line":297},[202,3497,3498],{"class":1076},"      -",[202,3500,3501],{"class":246}," 7676:443\n",[202,3503,3504,3507],{"class":233,"line":1099},[202,3505,3506],{"class":1174},"    volumes",[202,3508,1157],{"class":322},[202,3510,3511,3513],{"class":233,"line":1108},[202,3512,3498],{"class":1076},[202,3514,3515],{"class":246}," .\u002Fnginx.conf:\u002Fetc\u002Fnginx\u002Fnginx.conf:ro\n",[202,3517,3518,3520],{"class":233,"line":1116},[202,3519,3498],{"class":1076},[202,3521,3522],{"class":246}," .\u002Fcerts:\u002Fcerts:ro\n",[15,3524,3525],{},"今回はポート7676で待ち受けるように。あとは立ち上げるだけです。",[223,3527,3529],{"className":2323,"code":3528,"language":2325,"meta":89,"style":89},"sudo docker compose up -d\n",[229,3530,3531],{"__ignoreMap":89},[202,3532,3533,3536,3538,3540,3542],{"class":233,"line":234},[202,3534,3535],{"class":237},"sudo",[202,3537,2826],{"class":246},[202,3539,2742],{"class":246},[202,3541,2745],{"class":246},[202,3543,2748],{"class":246},[15,3545,3546,3547,3549],{},"curlを実行してみて、返ってくれば大丈夫です。",[19,3548],{},[195,3550],{"alt":89,"src":3551},"https:\u002F\u002Fstorage.googleapis.com\u002Fzenn-user-upload\u002Fab30bb4f1a28-20251222.png",[15,3553,3554],{},"次にSHA-256のフィンガープリントを抽出します。",[223,3556,3558],{"className":2323,"code":3557,"language":2325,"meta":89,"style":89},"openssl x509 -noout -fingerprint -sha256 -inform pem -in certs\u002Ffullchain.pem | tr -d :\n",[229,3559,3560],{"__ignoreMap":89},[202,3561,3562,3564,3567,3570,3573,3575,3578,3581,3584,3587,3590,3593,3596],{"class":233,"line":234},[202,3563,3308],{"class":237},[202,3565,3566],{"class":246}," x509",[202,3568,3569],{"class":246}," -noout",[202,3571,3572],{"class":246}," -fingerprint",[202,3574,3323],{"class":246},[202,3576,3577],{"class":246}," -inform",[202,3579,3580],{"class":246}," pem",[202,3582,3583],{"class":246}," -in",[202,3585,3586],{"class":246}," certs\u002Ffullchain.pem",[202,3588,3589],{"class":322}," |",[202,3591,3592],{"class":237}," tr",[202,3594,3595],{"class":246}," -d",[202,3597,3598],{"class":246}," :\n",[15,3600,3601],{},"上のコマンドを実行して",[223,3603,3606],{"className":3604,"code":3605,"language":649,"meta":89},[647],"sha256 Fingerprint=98D.........\n",[229,3607,3605],{"__ignoreMap":89},[15,3609,3610,3611,3614],{},"みたいなのが得られます。",[229,3612,3613],{},"Fingerprint=","以降の文字列を控えておきましょう。",[15,3616,3617,3620,3622,3623,3625,3628,3630,3631,3633,3636,3638],{},[195,3618],{"alt":89,"src":3619},"https:\u002F\u002Fstorage.googleapis.com\u002Fzenn-user-upload\u002Fe8920360a2dd-20251222.png",[19,3621],{},"\nZeroTrustの管理画面のサイドバーの「チームとリソース」から「デバイス」を開き、「デバイスプロファイル」タブに移動します。",[19,3624],{},[195,3626],{"alt":89,"src":3627},"https:\u002F\u002Fstorage.googleapis.com\u002Fzenn-user-upload\u002F82abc7f75759-20251222.png",[19,3629],{},"\n「管理ネットワーク」を見つけ、「新しい管理ネットワークを追加する」をクリックします。",[19,3632],{},[195,3634],{"alt":89,"src":3635},"https:\u002F\u002Fstorage.googleapis.com\u002Fzenn-user-upload\u002Fde57cbe5f878-20251222.png",[19,3637],{},"\n名前は適当なものを、ホストとポートは先程立てたWebサーバーのものを、SHA-256は先程控えたフィンガープリントを入力し「保存」",[11,3640,3641],{"id":3641},"スプリットトンネルの設定",[15,3643,3644,3645,3647,3650,3652,3653,3655,3658,3660,3661,3663,3666,3668,3669,3672,3673,3676,3677,3679,3682,3684,3685,3687,3690,3692,3693,3695,3696,3698,3699,3701,3704,3706],{},"この設定が結構重要です。",[19,3646],{},[195,3648],{"alt":89,"src":3649},"https:\u002F\u002Fstorage.googleapis.com\u002Fzenn-user-upload\u002F12c55b47f3a1-20251222.png",[19,3651],{},"\nさっきの「デバイスプロファイル」タブの画面まで戻り、プロファイル一覧の「デフォルト」の三点リーダーを開き、「設定」をクリックします。",[19,3654],{},[195,3656],{"alt":89,"src":3657},"https:\u002F\u002Fstorage.googleapis.com\u002Fzenn-user-upload\u002F3610d1996239-20251222.png",[19,3659],{},"\n「スプリットトンネル」の項目を見つけ、「IPとドメインを除外する」にチェックが入っていることを確認して「管理」をクリックします。",[19,3662],{},[195,3664],{"alt":89,"src":3665},"https:\u002F\u002Fstorage.googleapis.com\u002Fzenn-user-upload\u002Ff576126a633e-20251222.png",[19,3667],{},"\n開いたら",[229,3670,3671],{},"10.0.0.0\u002F8","と",[229,3674,3675],{},"192.168.0.0\u002F16","にチェックを入れ、「アクション」から「削除を確認」をクリックします。削除できたら前の画面に戻り、一番下にある「プロファイルを保存」をクリック。",[19,3678],{},[195,3680],{"alt":89,"src":3681},"https:\u002F\u002Fstorage.googleapis.com\u002Fzenn-user-upload\u002F7cd9d51be6b9-20251222.png",[19,3683],{},"\nプロファイル一覧画面で「新しいプロフィールを作成」をクリック。",[19,3686],{},[195,3688],{"alt":89,"src":3689},"https:\u002F\u002Fstorage.googleapis.com\u002Fzenn-user-upload\u002F55b27bfe612d-20251222.png",[19,3691],{},"\n名前は適当に、式はセレクターに「管理ネットワーク」オペレーターに「is」値を先程作成した管理ネットワークにする。",[19,3694],{},"\nこれを設定したら一番下にある「プロファイルを作成」をクリックする。",[19,3697],{},"\n続いてさっき新たに作成したプロファイルの設定画面を開き、スプリットトンネルが除外になっていることを確認し「管理」を開く。",[19,3700],{},[195,3702],{"alt":89,"src":3703},"https:\u002F\u002Fstorage.googleapis.com\u002Fzenn-user-upload\u002Fb2a86a41b727-20251222.png",[19,3705],{},"\nセレクターを「IP Address」に、値を家のCIDRにして宛先を保存して、前の画面に戻り、一番下の「プロファイルを保存」をクリックします。",[11,3708,3710],{"id":3709},"warpクライアントをインストール","WARPクライアントをインストール",[15,3712,3713],{},[22,3714,3717],{"href":3715,"rel":3716},"https:\u002F\u002Fdevelopers.cloudflare.com\u002Fcloudflare-one\u002Fteam-and-resources\u002Fdevices\u002Fwarp\u002Fdownload-warp\u002F",[26],"Cloudflare WARP ダウンロード",[15,3719,3720,3721,3723,3724,3726,3729,3731,3732,3734,3737,3739,3740,3742,3745,3747,3748,3750,3753,3755,3756,3758,3761,3763],{},"からCloudflare WARPをダウンロードしてインストールします。",[19,3722],{},"\nインストールが終わり起動したらシステムトレイアイコンをクリックして",[19,3725],{},[195,3727],{"alt":89,"src":3728},"https:\u002F\u002Fstorage.googleapis.com\u002Fzenn-user-upload\u002F0797dd0b41b6-20251223.png",[19,3730],{},"\n歯車アイコンをクリックし、環境設定を開きます。",[19,3733],{},[195,3735],{"alt":89,"src":3736},"https:\u002F\u002Fstorage.googleapis.com\u002Fzenn-user-upload\u002F9a10ad48ea98-20251223.png",[19,3738],{},"\n設定ウィンドウのサイドバーの「アカウント」を開き、「Cloudflare Zero Trustにログイン」をクリックし、表示される案内を読み次へとか同意するを押してると",[19,3741],{},[195,3743],{"alt":89,"src":3744},"https:\u002F\u002Fstorage.googleapis.com\u002Fzenn-user-upload\u002Fd97dbc985b37-20251223.png",[19,3746],{},"\n上の画像のようなウィンドウが出ます。ここには設定したチーム名を入力します。",[19,3749],{},[195,3751],{"alt":89,"src":3752},"https:\u002F\u002Fstorage.googleapis.com\u002Fzenn-user-upload\u002Ff230ca9a4cfe-20251223.png",[19,3754],{},"\nログインが成功するとWARPを開くか聞かれるので開きます。",[19,3757],{},[195,3759],{"alt":89,"src":3760},"https:\u002F\u002Fstorage.googleapis.com\u002Fzenn-user-upload\u002F06e6fae4b43a-20251223.png",[19,3762],{},"\n表示がオレンジ色のWARPから青色のZero TrustになっていればOKです。",[11,3765,3766],{"id":3766},"テスト",[15,3768,3769,3770,3773,3774,3776,3779,3781],{},"Cloudflare WARPをインストールしたスマホからモバイルデータを使用して",[229,3771,3772],{},"192.168.0.30","にアクセスしてみました。",[19,3775],{},[195,3777],{"alt":89,"src":3778},"https:\u002F\u002Fstorage.googleapis.com\u002Fzenn-user-upload\u002Fe7658c2e2b05-20251223.jpg",[19,3780],{},"\nはい。出来ていますね。",[11,3783,3784],{"id":3784},"今回のポイント",[15,3786,3787,3788,3790],{},"実は他の記事で紹介されている方法では家の中で使うときにも一度Cloudflareを経由してしまい、遅くなってしまうんですよね。",[19,3789],{},"\nそこで「管理ネットワーク」という機能を使って家の中にいるのかを判断してプロファイルを切り替えるっていうそういう感じにしました。",[11,3792,668],{"id":668},[15,3794,3795,3796,3798],{},"以上です。やたら長いので分けて書けば良かったかもしれぬ。",[19,3797],{},"\nn番煎じ感のある記事で申し訳ないです。",[679,3800,3801],{},"html .default .shiki span {color: var(--shiki-default);background: var(--shiki-default-bg);font-style: var(--shiki-default-font-style);font-weight: var(--shiki-default-font-weight);text-decoration: var(--shiki-default-text-decoration);}html .shiki span {color: var(--shiki-default);background: var(--shiki-default-bg);font-style: var(--shiki-default-font-style);font-weight: var(--shiki-default-font-weight);text-decoration: var(--shiki-default-text-decoration);}html pre.shiki code .siK8c, html code.shiki .siK8c{--shiki-default:#8AADF4;--shiki-default-font-style:italic}html pre.shiki code .sSZ1V, html code.shiki .sSZ1V{--shiki-default:#A6DA95}html pre.shiki code .s7Qn8, html code.shiki .s7Qn8{--shiki-default:#F5A97F}html pre.shiki code .s57MT, html code.shiki .s57MT{--shiki-default:#8AADF4}html pre.shiki code .sXptk, html code.shiki .sXptk{--shiki-default:#8BD5CA}html pre.shiki code .slVFb, html code.shiki .slVFb{--shiki-default:#939AB7}",{"title":89,"searchDepth":90,"depth":90,"links":3803},[3804,3805,3806,3807,3808,3809,3810,3811,3812,3813,3814,3815],{"id":2927,"depth":90,"text":2928},{"id":2973,"depth":90,"text":2973},{"id":2986,"depth":90,"text":2986},{"id":3014,"depth":90,"text":3015},{"id":3159,"depth":90,"text":3159},{"id":3230,"depth":90,"text":3230},{"id":3272,"depth":90,"text":3273},{"id":3641,"depth":90,"text":3641},{"id":3709,"depth":90,"text":3710},{"id":3766,"depth":90,"text":3766},{"id":3784,"depth":90,"text":3784},{"id":668,"depth":90,"text":668},"2025-12-23","Cloudflare Zero Trustを使用して、外部から自宅のネットワークに安全にアクセスし、かつ宅内では直結で通信する「管理ネットワーク」の設定方法を解説します。",{},"\u002Fblog\u002Fcloudflare-zero-trust-home-access",{"title":2922,"description":3817},"blog\u002Fcloudflare-zero-trust-home-access",[3823,3825,3827],{"name":3824},"Cloudflare",{"name":3826},"Zero Trust",{"name":45},"2ldmvCO7cXBji8VmaWJxMtWP7zg5epmK9e9yU5FuyqI",{"id":3830,"title":3831,"body":3832,"date":4149,"description":4150,"extension":102,"meta":4151,"navigation":104,"path":4152,"seo":4153,"stem":4154,"tags":4155,"__hash__":4157},"blog\u002Fblog\u002Fkoukounoaida_yattakoto.md","高校の卒業が確定したので3年間やったことを振り返る",{"type":8,"value":3833,"toc":4124},[3834,3838,3844,3850,3854,3858,3864,3867,3871,3877,3880,3883,3889,3903,3906,3918,3921,3934,3940,3943,3947,3950,3959,3962,3965,3969,3972,3978,3981,3995,3998,4001,4005,4009,4015,4019,4025,4028,4031,4037,4043,4046,4050,4056,4059,4062,4066,4069,4075,4078,4084,4087,4096,4100,4103,4106,4109,4115,4121],[11,3835,3837],{"id":3836},"高校卒業","高校卒業🎉",[15,3839,3840,3841,3843],{},"単位認定のテストを終えて、嬉しいかな高校の卒業が確定しました。",[19,3842],{},"\n進路は決まっていません😭。",[15,3845,3846,3847,3849],{},"記念というか、自分の中で振り返るという目的で、高校生の間に何をしていたかを振り返ってみようかなって思います。",[19,3848],{},"\n面接のための振り返りかもしれません。ハハハハ",[11,3851,3853],{"id":3852},"_1年生","1年生",[36,3855,3857],{"id":3856},"マイクラサーバー初構築","マイクラサーバー初構築!!",[15,3859,3860,3861,3863],{},"使わなくなったSurfaceBookにUbuntuを導入して、マイクラサーバーを構築・運用しました。",[19,3862],{},"\nあの頃はCLIに慣れていなかったのでGUIでネットワークの設定を済ませ、GUIを無効化してサーバーとして運用していましたね。",[15,3865,3866],{},"なおそのSurfaceBookはバッテリーが膨張して廃棄しました。蓋がパカって開いてましたw",[36,3868,3870],{"id":3869},"misskeyインスタンスの構築","Misskeyインスタンスの構築",[15,3872,3873,3874,3876],{},"Dockerを使用してMisskeyを構築しました。",[19,3875],{},"\n構築といってもドキュメントに書いてあるコマンドをポイポイ貼るだけなので、とても簡単です。",[15,3878,3879],{},"公開のためにCloudflare Tunnelを使用しました。とても便利。",[36,3881,3882],{"id":3882},"自作パソコンを組む",[15,3884,3885,3886,3888],{},"今のパソコンを組みます。",[19,3887],{},"\n前使っていたパソコンは",[134,3890,3891,3894,3897,3900],{},[137,3892,3893],{},"CPU: Intel Core i7 4700K",[137,3895,3896],{},"RAM: DDR3 24GB",[137,3898,3899],{},"GPU: NVIDIA GeForce RTX 3060",[137,3901,3902],{},"SSD: 256GB",[15,3904,3905],{},"って感じのよわよわパソコンだったので、適当にパーツを買い、",[134,3907,3908,3911,3914,3916],{},[137,3909,3910],{},"CPU: AMD Ryzen 5 5600G",[137,3912,3913],{},"RAM: DDR4 32GB",[137,3915,3899],{},[137,3917,3902],{},[15,3919,3920],{},"って感じに微妙にアップグレードしました。当時からスペックアップはしていて、現状は",[134,3922,3923,3926,3928,3931],{},[137,3924,3925],{},"CPU: AMD Ryzen 7 5700X",[137,3927,3913],{},[137,3929,3930],{},"GPU: NVIDIA GeForce RTX 4060 Ti 16GB",[137,3932,3933],{},"SSD: 2TB",[15,3935,3936,3937,3939],{},"になっています。AM5はメモリ高騰が落ち着くまで移行できない気がしています。",[19,3938],{},"\nグラボが壊れたらお財布が爆死します；；",[15,3941,3942],{},"…みたいな感じで1年生を過ごしていましたね〜。何にもしてない気がします！！",[11,3944,3946],{"id":3945},"_2年生","2年生",[36,3948,3949],{"id":3949},"中古ワークステーション購入",[15,3951,3952,3953,3955,3956,3958],{},"24時間動かすサーバー用途として中古のワークステーションを購入しました。",[19,3954],{},"\nCPUがXeon E3-1225 v5で、RAMが16GB、256GBのSSDがついてるやつ。",[19,3957],{},"\n中古で大体22000円くらいだったかな？安い！",[15,3960,3961],{},"ここら辺からLinuxについて理解を深め始めています。今も初心者のままではありますけど。",[15,3963,3964],{},"このサーバーはメディアサーバー、ファイルサーバー、VaultWardenを動かして運用しています。",[36,3966,3968],{"id":3967},"wordpress構築","WordPress構築",[15,3970,3971],{},"nginxとphp-fpmを組み合わせ、WordPressを構築しました。",[15,3973,3974,3975,3977],{},"自宅サーバーで公開はCloudflare Tunnel経由ですがパフォーマンスをそこそこ高く構築できたので満足でした。",[19,3976],{},"\nテーマはyStandardを使用していました。",[15,3979,3980],{},"無駄にセキュリティを固めて",[134,3982,3983,3986,3989,3992],{},[137,3984,3985],{},"ログイン画面パス変更",[137,3987,3988],{},"ログイン画面から管理画面への遷移を防ぐ",[137,3990,3991],{},"IPホワイトリスト",[137,3993,3994],{},"ログイン試行回数制限",[15,3996,3997],{},"みたいなことを導入してました。意外と攻撃されるものなんです。",[15,3999,4000],{},"…って感じ。この年も何もしていない。",[11,4002,4004],{"id":4003},"_3年生","3年生",[36,4006,4008],{"id":4007},"raspberry-pi入手","Raspberry Pi入手",[15,4010,4011,4012,4014],{},"親からラズパイ3b+をもらいました。",[19,4013],{},"\n性能が低いのでなんでもできるってわけではありませんでしたが、AirPlayのレシーバーとして使ってました。",[36,4016,4018],{"id":4017},"astronuxtでブログ作成","Astro・Nuxtでブログ作成",[15,4020,4021,4022,4024],{},"AstroとNuxtを触り始めたんです。",[19,4023],{},"\nこのブログはAstro製ですが、一応Nuxtでも作って見てたんです。",[15,4026,4027],{},"私にはJS,TS,CSSの素養が無いので、今もそんなに書けません。",[36,4029,4030],{"id":4030},"ドアチャイムを作成",[15,4032,4033,4034,4036],{},"父親の知人のお店のドアチャイムを作成しました。",[19,4035],{},"\nラズパイとセンサーを組み合わせドアが開いた時にフォルダ内のランダムな音源を再生するって感じの。",[15,4038,4039,4040,4042],{},"その父親の知人はパソコンに詳しく無いためsmbでドラッグ&ドロップするだけで音源を追加できるようにしました。",[19,4041],{},"\n構築用のスクリプトもあるので、壊れてもすぐに再設置が可能っていう。",[15,4044,4045],{},"言語はPythonだよ。",[36,4047,4049],{"id":4048},"archlinux入門","ArchLinux入門",[15,4051,4052,4053,4055],{},"ArchLinuxを触り始めたのがこの年だった気がします。",[19,4054],{},"\n最初はGnomeを使用していましたがやっぱり「Hyprland触ってみたい！！」ってなって、設定を色々してイケてるデスクトップを作成しました。",[15,4057,4058],{},"結局保守が面倒くさくてGnomeに戻したんですけどね。",[15,4060,4061],{},"あとLinuxとNvidiaの相性の悪さを痛感した。マジふざけんな!!!!!!",[11,4063,4065],{"id":4064},"all","ALL",[36,4067,4068],{"id":1025},"Python",[15,4070,4071,4072,4074],{},"中学の時から触っていましたが高校の間もPythonを触ってましたね。",[19,4073],{},"\nなんていうか、変なツールを開発したり、APIを作ったりDiscordのBOTを作ったりとか。",[36,4076,4077],{"id":2739},"Docker",[15,4079,4080,4081,4083],{},"Dockerも環境を汚さないためになんとか使っています。",[19,4082],{},"\nいまだにDockerfileも満足に書けないくらいには定着しないので、もう少し本腰を入れないと。",[36,4085,3824],{"id":4086},"cloudflare",[15,4088,4089,4090,4092,4093,4095],{},"Cloudflareのサービスを結構使ってます。",[19,4091],{},"\nこのブログだってCloudflare Workersを使用していますし、自分用のいくつかのサービスもCloudflare Tunnelで公開しているし、",[19,4094],{},"\n宅外から宅内のネットワークにアクセスするとかも、Cloudflareのサービスを利用しています。",[36,4097,4099],{"id":4098},"linux","Linux",[15,4101,4102],{},"Linuxをなんとか触っていました。UbuntuはもちろんArch,RHEL系も使ったりしましたね。",[15,4104,4105],{},"基本的なコマンドは覚えた気がします。Windowsから乗り換えれるくらいには覚えたけど、AviUtlが動かないのとNvidiaとの相性が悪いので乗り換えはできていません。",[11,4107,4108],{"id":4108},"最後に",[15,4110,4111,4112,4114],{},"この3年間を振り返ると特に大きな成果も努力もなかったような気がします。",[19,4113],{},"\nいや、色々やってた気もするんだけどここに書くほどでも無い感じかなぁ。",[15,4116,4117,4118,4120],{},"気になるものを手当たり次第手を伸ばして触っているだけなんでね。",[19,4119],{},"\n今後は一つの分野をしっかりと学んでいきたいという意気込みがあります。",[15,4122,4123],{},"それでは、また。",{"title":89,"searchDepth":90,"depth":90,"links":4125},[4126,4127,4132,4136,4142,4148],{"id":3836,"depth":90,"text":3837},{"id":3852,"depth":90,"text":3853,"children":4128},[4129,4130,4131],{"id":3856,"depth":96,"text":3857},{"id":3869,"depth":96,"text":3870},{"id":3882,"depth":96,"text":3882},{"id":3945,"depth":90,"text":3946,"children":4133},[4134,4135],{"id":3949,"depth":96,"text":3949},{"id":3967,"depth":96,"text":3968},{"id":4003,"depth":90,"text":4004,"children":4137},[4138,4139,4140,4141],{"id":4007,"depth":96,"text":4008},{"id":4017,"depth":96,"text":4018},{"id":4030,"depth":96,"text":4030},{"id":4048,"depth":96,"text":4049},{"id":4064,"depth":90,"text":4065,"children":4143},[4144,4145,4146,4147],{"id":1025,"depth":96,"text":4068},{"id":2739,"depth":96,"text":4077},{"id":4086,"depth":96,"text":3824},{"id":4098,"depth":96,"text":4099},{"id":4108,"depth":90,"text":4108},"2025-12-19","高校の3年間にやったことを振り返ります。",{},"\u002Fblog\u002Fkoukounoaida_yattakoto",{"title":3831,"description":4150},"blog\u002Fkoukounoaida_yattakoto",[4156],{"name":110},"atdYEpzT49IZ6flvGWizAuxqgrKI4KgaEoQ-EJmB4PI",1775738148072]