240912-设置WSL中的Ollama可在局域网访问

A. 最终效果

B. 设置Ollama(前提)

bash 复制代码
sudo vim /etc/systemd/system/ollama.service
txt 复制代码
[Unit]
Description=Ollama Service
After=network-online.target

[Service]
ExecStart=/usr/bin/ollama serve
User=ollama
Group=ollama
Restart=always
RestartSec=3
Environment="PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin"
Environment="OLLAMA_MODELS=/home/lgk/ollama/models"
Environment="OLLAMA_HOST=0.0.0.0:11434"

[Install]
WantedBy=default.target

C. 启动Ollama(关键)

  • 无效操作
bash 复制代码
ollama serve
  • 有效操作
bash 复制代码
OLLAMA_HOST=0.0.0.0:<端口> ollama serve
  • 失效分析
  • 取消防火墙
禁用 WSL2 防火墙(或配置防火墙规则)

Windows 中的防火墙可能会阻止流量从 Windows 主机到 WSL2 的虚拟网络接口。你可以尝试通过以下步骤来暂时禁用防火墙以进行测试:

  1. 打开 PowerShell,以管理员身份运行以下命令:

    powershell 复制代码
    Set-NetFirewallProfile -Profile Domain,Public,Private -Enabled False
  2. 然后再次尝试使用 curl 访问 WSL2 中的服务:

    powershell 复制代码
    curl http://172.29.75.201:11434

    如果可以正常连接,那么你可以重新启用防火墙,并创建一条允许访问端口 11434 的规则。重新启用防火墙的命令是:

    powershell 复制代码
    Set-NetFirewallProfile -Profile Domain,Public,Private -Enabled True
重启防火墙

你可以通过以下步骤在 Windows 和 Linux 中重启防火墙:

在 Windows 中重启防火墙
  1. 打开 PowerShell命令提示符,以管理员身份运行。

  2. 运行以下命令来重启 Windows 防火墙:

    • 禁用防火墙

      powershell 复制代码
      Set-NetFirewallProfile -Profile Domain,Public,Private -Enabled False
    • 重新启用防火墙

      powershell 复制代码
      Set-NetFirewallProfile -Profile Domain,Public,Private -Enabled True
在 Linux(WSL2)中重启防火墙

如果你在 WSL2 中使用 ufw(Uncomplicated Firewall),可以通过以下命令管理防火墙:

  1. 以管理员权限运行以下命令来检查 ufw 是否安装:

    bash 复制代码
    sudo ufw status
  2. 如果 ufw 没有启用或安装,首先启用它:

    bash 复制代码
    sudo ufw enable
  3. 禁用 ufw

    bash 复制代码
    sudo ufw disable
  4. 重新启用 ufw

    bash 复制代码
    sudo ufw enable
检查防火墙状态
  • Windows:你可以使用以下命令检查防火墙是否已启用:

    powershell 复制代码
    Get-NetFirewallProfile -Profile Domain,Public,Private
  • Linux :运行以下命令检查 ufw 状态:

    bash 复制代码
    sudo ufw status

这样你就可以在两种系统中重启防火墙了。

D. 参考文献

相关推荐
Alan_7512 小时前
高并发架构优化实战:Redis 调优、数据库扩展与协同架构三大核心模块
api
匹诺曹i36718 小时前
docx 报表进 OpenClaw 本地 RAG:memory 索引实践与 6 个坑
ollama
AlfredZhao2 天前
生产环境里,为什么不建议把普通端口直接暴露到公网?
linux·https·443·80
戴为沐3 天前
Linux内存扩容指南
linux
zylyehuo3 天前
Linux 彻底且安全地删除文件
linux
用户805533698034 天前
主线 U-Boot 上 RK3506:和闭源 rkbin 拔河的三个隐性契约
linux·嵌入式
用户034095297914 天前
linux fcitx 5 雾凇拼音 设置在中文输入法下仍然输入英文标点
linux
Web3探索者6 天前
可视化服务器管理和传统命令行区别是什么?新手教程:Linux 运维到底该用图形界面还是 SSH 命令行?
linux·ssh
zylyehuo6 天前
Linux系统中网线与USB网络共享冲突
linux
用户7783366132116 天前
从 Serper 切到 SERP API:200 行代码 diff 实战
api