FreeBSD 中文社区 2025 第二季度问卷调查
FreeBSD 中文社区(CFC)
VitePress 镜像站QQ 群 787969044视频教程Ⅰ视频教程Ⅱ
  • FreeBSD 操作系统研究导论
  • 中文期刊
  • 状态报告
  • 发行说明
  • 手册
  • 网络文章集锦
  • 笔记本支持报告
  • Port 开发者手册
  • 架构手册
  • 开发者手册
  • 中文 man 手册
  • 文章与书籍
  • UNIX 四分之一世纪
  • Unix 痛恨者手册
  • FreeBSD 操作系统研究导论(第三版:草稿)
  • 编辑日志
  • 贡献指南与开放任务
  • 目录
  • 前言
    • 致读者
    • 致谢
    • 初版序言:好望角与塔吊
    • 再版序言:回到复制粘贴,面向教程本身
    • 三版序言:且有大觉而后知此其大梦也(草稿)
    • 本书的组织结构
    • 本书中使用的一些约定
  • 第 1 章 FreeBSD 初见
    • 1.1 操作系统的历程:UNIX、BSD 和 Linux
    • 1.2 欢迎来到 FreeBSD
    • 1.3 关于 FreeBSD 项目
    • 1.4 George Berkeley(乔治·贝克莱)与 BSD 命名的文化背景
    • 1.5 加州大学伯克利分校和“Fiat Lux”(要有光)
  • 第 2 章 安装 FreeBSD
    • 2.1 安装前的准备工作
    • 2.2 使用 bsdinstall 开始安装
    • 2.3 键盘布局和主机名
    • 2.4 选择安装组件
    • 2.5 分配磁盘空间
    • 2.6 设置 root 密码
    • 2.7 网络设置
    • 2.8 时区、服务、安全、固件和账户
    • 2.9 完成安装
    • 2.10 故障排除
  • 第 3 章 FreeBSD 基础
    • 3.1 Windows 用户迁移指南
    • 3.2 Linux 用户迁移指南
    • 3.3 虚拟控制台和终端
    • 3.4 认识 shell
    • 3.5 命令行基础
    • 3.6 文本编辑器
    • 3.7 用户和基本账户管理
    • 3.8 权限
    • 3.9 sudo 和 doas
    • 3.10 文件系统的挂载和卸载
    • 3.11 磁盘结构
    • 3.12 目录结构
  • 第 4 章 软件管理和系统升级
    • 4.1 FreeBSD 镜像站现状
    • 4.2 更换 FreeBSD 软件源
    • 4.3 gitup 的用法
    • 4.4 使用 pkg 管理二进制包
    • 4.5 使用 Ports 以源代码方式安装软件
    • 4.6 使用 DVD 安装软件
    • 4.7 使用 freebsd-update 更新 FreeBSD
    • 4.8 使用源代码更新 FreeBSD
    • 4.9 使用 pkgbase 更新 FreeBSD
  • 第 5 章 桌面环境
    • 5.1 Intel 和 AMD 显卡驱动
    • 5.2 NVIDIA 显卡驱动
    • 5.3 KDE6
    • 5.4 GNOME
    • 5.5 Mate
    • 5.6 Xfce
    • 5.7 Cinnamon
    • 5.8 Lumina
    • 5.9 LXQt
    • 5.10 Budgie
    • 5.11 CDE
    • 5.12 LXDE
    • 5.13 主题美化
    • 5.14 远程桌面
    • 5.15 启用 root 桌面登录
  • 第 6 章 本地化——i18n/L10n
    • 6.1 本地化环境变量
    • 6.2 Fcitx 输入法框架
    • 6.3 IBus 输入法框架
    • 6.4 五笔输入法
    • 6.5 网络浏览器
    • 6.6 QQ(Linux 版)
    • 6.7 更换字体
    • 6.8 金山 WPS(Linux 版)
    • 6.9 压缩和解压
    • 6.10 微信(Linux 版)
  • 第 7 章 多媒体和外部设备
    • 7.1 音频设备配置
    • 7.2 蓝牙
    • 7.3 打印机
    • 7.4 触摸板
    • 7.5 音频播放器
    • 7.6 视频播放器
    • 7.7 多媒体处理工具
  • 第 8 章 代理服务器
    • 8.1 HTTP 代理
    • 8.2 V2ray
    • 8.3 Mihomo(原 Clash)
    • 8.4 OpenVPN
  • 第 9 章 Jail
    • 9.1 配置 Jail
    • 9.2 更新 jail
    • 9.3 使用 Qjail 管理 Jail
    • 9.4 Linux Jail
  • 第 10 章 虚拟化和容器
    • 10.1 通过 BVCP 以网页管理 BHyve
    • 10.2 使用 bhyve 安装 Windows 11(vm-bhyve)
    • 10.3 Podman
    • 10.4 在 FreeBSD 上安装 VirtualBox
  • 第 11 章 FreeBSD 安装实践
    • 11.1 使用 Hyper-V 安装 FreeBSD
    • 11.2 使用 VMware Workstation Pro 安装 FreeBSD
    • 11.3 使用 Virtual Box 安装 FreeBSD
    • 11.4 手动安装双系统(先安装 FreeBSD)
    • 11.5 手动安装双系统(后安装 FreeBSD)
    • 11.6 基于 Apple M1 & Parallels Desktop 20 安装 FreeBSD
    • 11.7 基于 Apple M1 & VMware Fusion Pro 安装 FreeBSD
    • 11.8 使用 Qemu 安装 RISC-V FreeBSD(基于 x86 Windows)
    • 11.9 云服务器安装 FreeBSD(基于腾讯云轻量云)
    • 11.10 配置 rEFInd(双系统用)
  • 第 12 章 窗口管理器
    • 12.1 bspwm
    • 12.2 IceWM
    • 12.3 i3wm
    • 12.4 Hyprland
    • 12.5 Window Maker
    • 12.6 Fluxbox
  • 第 13 章 FreeBSD 系统管理
    • 13.1 引导界面和虚拟控制台
    • 13.2 管理 FreeBSD 中的服务
    • 13.3 bsdconfig 系统配置工具
    • 13.4 SSH 配置和相关工具
    • 13.5 单用户模式和密码重置
    • 13.6 Grub、UEFI 和 efibootmgr
  • 第 14 章 网络管理
    • 14.1 设置网络
    • 14.2 无线网络
    • 14.3 USB 网络共享(USB tethering)
    • 14.4 TCP 堆栈
  • 第 15 章 FreeBSD 防火墙
    • 15.1 Fail2Ban(基于 IPFW、PF、IPF)
    • 15.2 Packet Filter(PF)
    • 15.3 IPFilter(IPF)
    • 15.4 ipfirewall(IPFW)
  • 第 16 章 服务器
    • 16.1 FTP 服务器
    • 16.2 MinIO 对象存储服务
    • 16.3 Gitlab-EE
    • 16.4 时间服务
    • 16.5 WildFly
    • 16.6 Rsync 同步服务
    • 16.7 Samba 服务器
    • 16.8 NFS 服务器
    • 16.9 Webmin
  • 第 17 章 Web 服务器和监控平台
    • 17.1 Apache
    • 17.2 Nginx
    • 17.3 PHP 8.X
    • 17.4 Zabbix 监控(基于 PostgreSQL)
    • 17.5 NextCloud——基于 PostgreSQL
    • 17.6 Telegraf+InfluxDB+Grafana 监控平台
    • 17.7 AList
    • 17.8 Prometheus 监控部署
    • 17.9 Tomcat
    • 17.10 Caddy
    • 17.11 OnlyOffice(基于 PostgreSQL)
  • 第 18 章 嵌入式平台
    • 18.1 树莓派简介
    • 18.2 树莓派安装 FreeBSD
    • 18.3 树莓派 FreeBSD 配置
    • 18.4 树莓派和 Linux 兼容层
    • 18.5 Radxa X4(x86)
  • 第 19 章 数据库管理
    • 19.1 PostgreSQL
    • 19.2 pgAdmin4
    • 19.3 MySQL 5.X
    • 19.4 MySQL 8.X
    • 19.5 MongoDB 8.0
  • 第 20 章 游戏、科学计算和专业工具
    • 20.1 游戏
    • 20.2 我的世界(Minecraft)
    • 20.3 科研和专业工具
  • 第 21 章 Linux 二进制兼容层
    • 21.1 Linux 兼容层实现
    • 21.2 RockyLinux 兼容层(FreeBSD Port)
    • 21.3 Ubuntu/Debian 兼容层
    • 21.4 ArchLinux 兼容层(基于 ArchLinux bootstrap)
    • 21.5 ArchLinux 兼容层(基于 archlinux-pacman)
    • 21.6 OpenSUSE 兼容层
    • 21.7 Gentoo Linux 兼容层
    • 21.8 Rocky Linux 兼容层
    • 21.9 Slackware Linux 兼容层
    • 21.10 Deepin 兼容层
    • 21.11 故障排除与未竟事宜
  • 第 22 章 开发生态与贡献社区
    • 22.1 如何报告 Bug
    • 22.2 如何开发一个 Port
    • 22.3 如何参与 FreeBSD 开发
    • 22.4 C/C++ 环境的配置
    • 22.5 Java 环境的配置
    • 22.6 QT 环境的配置
    • 22.7 Python 和 VS Code
    • 22.8 Rust/Go 环境的配置
    • 22.9 配置 Shell
    • 22.10 通过 IDA 7 调试 FreeBSD
    • 22.11 如何订阅 FreeBSD 的邮件列表
    • 22.12 code-server 和 clangd
    • 22.13 Node.js
    • 22.14 利用脚本自动生成 BSDlibc 库文本
  • 第 23 章 存储管理和文件系统
    • 23.1 自动挂载文件系统
    • 23.2 ZFS 文件系统
    • 23.3 磁盘扩容和分区调整
    • 23.4 Windows 文件系统
    • 23.5 Swap 交换分区的设置
    • 23.6 Linux 文件系统
  • 第 24 章 DragonFly BSD 入门
    • 24.1 DragonFly BSD 概述
    • 24.2 安装 DragonFly BSD
    • 24.3 配置 DragonFly BSD
  • 第 25 章 TwinCAT/BSD 入门
    • 25.1 TwinCAT/BSD 系统安装和基本配置
    • 25.2 TwinCAT/BSD 开发环境配置
  • 第 26 章 OpenBSD 入门
    • 26.1 OpenBSD 概述
    • 26.2 安装 OpenBSD
    • 26.3 配置 OpenBSD
    • 26.4 OpenBSD 包管理器
    • 26.5 桌面和其他软件
    • 26.6 在 RISC-V 开发板上安装 OpenBSD
    • 26.7 树莓派和 OpenBSD
  • 第 27 章 NetBSD 入门
    • 27.1 NetBSD 概述
    • 27.2 NetBSD 安装图解
    • 27.3 NetBSD 换源和包管理器
    • 27.4 桌面和中文环境常用软件
  • 附录 Ⅰ 计算机概论
    • 存储卡简介
    • 总线接口与协议
    • 网络基础
    • 操作系统
    • MySQL 数据库
  • 附录 Ⅱ 工具与资源
    • 适用于 FreeBSD 的以太网卡、USB 以太网卡和 USB 无线网卡
    • FreeBSD 桌面发行版评述
    • BSD 许可证概览
  • 附录 Ⅲ 文学故事
    • 我与 FreeBSD 的故事
    • 两次告别
    • 小说:大教堂与集市
    • 小说:吾乡何处
    • 小说:你与暗
    • 诗歌选
    • 杂记
  • 附录 Ⅳ 参考文献和术语
    • 参考书目
    • 术语表
由 GitBook 提供支持
LogoLogo

FreeBSD 中文社区(CFC) 2025

在本页
  • 安装
  • 查找相关的软件包
  • 启动
  • 浏览网页
  • 配置文件
  • 示例文件(Nginx + Typecho 伪静态 + SSL)
在GitHub上编辑
导出为 PDF
  1. 第 17 章 Web 服务器和监控平台

17.2 Nginx

安装

# pkg install nginx

或

# cd /usr/ports/www/nginx/ 
# make install clean

查找相关的软件包

  • ports: $ ls /usr/ports/www/ | grep nginx

  • pkg: $ pkg search -o nginx

启动

root@ykla:~ # service nginx enable
nginx enabled in /etc/rc.conf
root@ykla:~ # service nginx start
Performing sanity check on nginx configuration:
nginx: the configuration file /usr/local/etc/nginx/nginx.conf syntax is ok
nginx: configuration file /usr/local/etc/nginx/nginx.conf test is successful
Starting nginx.

你可以通过 sockstat -4 | grep nginx 检查 nginx 是否启动并正常运行:

root@ykla:~ # sockstat -4 | grep nginx
www      nginx       1154 6   tcp4   *:80                  *:*
root     nginx       1153 6   tcp4   *:80                  *:*

浏览网页

本机打开 localhost,或者 ip,如 http://192.168.179.150/:

配置文件

配置教程可参阅官方文档 。

本文仅简单说明 FreeBSD 中如何启动 Nginx 及 Nginx 的配置文件。

在 FreeBSD 中,Nginx 的配置文件位于 /usr/local/etc/nginx/ 中,而主要的配置文件则在 /usr/local/etc/nginx/nginx.conf。

默认配置中 Nginx 的根目录为 /usr/local/www/nginx/,如果需要更改目录位置,请将 /usr/local/etc/nginx/nginx.conf 中的

root	/usr/local/www/nginx;

改成你想要的目录位置,例如 root /path/to/new/webroot

示例文件(Nginx + Typecho 伪静态 + SSL)

#user  nobody;
worker_processes  1;

# This default error log path is compiled-in to make sure configuration parsing
# errors are logged somewhere, especially during unattended boot when stderr
# isn't normally logged anywhere. This path will be touched on every nginx
# start regardless of error log location configured here. See
# https://trac.nginx.org/nginx/ticket/147 for more info.
#
#error_log  /var/log/nginx/error.log;
#

#pid        logs/nginx.pid;


events {
    worker_connections  1024;
}


http {
    include       mime.types;
    default_type  application/octet-stream;

    #log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
    #                  '$status $body_bytes_sent "$http_referer" '
    #                  '"$http_user_agent" "$http_x_forwarded_for"';

    #access_log  logs/access.log  main;

    sendfile        on;
    #tcp_nopush     on;

    #keepalive_timeout  0;
    keepalive_timeout  65;

    #gzip  on;

    server {
        listen       80;
        server_name  localhost;

        #charset koi8-r;

        #access_log  logs/host.access.log  main;

        location / {
            root   /usr/local/www/nginx;
            index  index.html index.htm index.php;
if (-f $request_filename/index.html){
rewrite (.*) $1/index.html break;
}
if (-f $request_filename/index.php){
rewrite (.*) $1/index.php;
}
if (!-f $request_filename){
rewrite (.*) /index.php;}
 }


location ~ .*.php(/.*)*$ {
            root           /usr/local/www/nginx;
            fastcgi_pass   127.0.0.1:9000;
            fastcgi_index  index.php;
            fastcgi_param  SCRIPT_FILENAME $request_filename;
            include        fastcgi_params;
        }





  #location ~ .*.php(/.*)*$ {
   #         include fastcgi_params;
    #        fastcgi_pass  127.0.0.1:9000;
     #   }

        #error_page  404              /404.html;

        # redirect server error pages to the static page /50x.html
        #
        error_page   500 502 503 504  /50x.html;
        location = /50x.html {
            root   /usr/local/www/nginx-dist;
        }

        # proxy the PHP scripts to Apache listening on 127.0.0.1:80
        #
        #location ~ .php$ {
        #    proxy_pass   http://127.0.0.1;
        #}

        # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000
        #
        location ~ .*.php(/.*)*$ {
            root           /usr/local/www/nginx;
            fastcgi_pass   127.0.0.1:9000;
            fastcgi_index  index.php;
            fastcgi_param  SCRIPT_FILENAME $request_filename;
            include        fastcgi_params;
        }

        # deny access to .htaccess files, if Apache's document root
        # concurs with nginx's one
        #
        #location ~ /.ht {
        #    deny  all;
        #}
    }


    # another virtual host using mix of IP-, name-, and port-based configuration
    #
    #server {
    #    listen       8000;
    #    listen       somename:8080;
    #    server_name  somename  alias  another.alias;

    #    location / {
    #        root   html;
    #        index  index.html index.htm;
    #    }
    #}


    # HTTPS server
    #
    server {
       listen       443;
       server_name  localhost;

        ssl_certificate      /usr/local/etc/nginx/fbxs.crt;
      ssl_certificate_key   /usr/local/etc/nginx/fbxs.key;

      ssl on;
        ssl_certificate fbxs.crt;
        ssl_certificate_key fbxs.key;
        ssl_session_timeout 5m;
        ssl_protocols TLSv1 TLSv1.1 TLSv1.2; #按照这个协议配置
        ssl_ciphers ECDHE-RSA-AES128-GCM-SHA256:HIGH:!aNULL:!MD5:!RC4:!DHE;#按照这个套件配置
        ssl_prefer_server_ciphers on;
location ~ .*.php(/.*)*$ {
            root           /usr/local/www/nginx-dist;
            fastcgi_pass   127.0.0.1:9000;
            fastcgi_index  index.php;
            fastcgi_param  SCRIPT_FILENAME $request_filename;
            include        fastcgi_params;
        }
        location / {
            root   /usr/local/www/nginx-dist;
            index  index.php;
 }
      }

}
上一页17.1 Apache下一页17.3 PHP 8.X

最后更新于17小时前

NGINX FreeBSD