Nginx服务器初期基本配置指南
安装与启动Nginx
1. 安装过程
操作系统 | 安装方法 |
Ubuntu | sudo apt-get update && sudo apt-get install nginx |
CentOS | sudo yum install epel-release && sudo yum install nginx |
macOS | 使用Homebrew:brew install nginx |
2. 启动命令
启动:sudo service nginx start
停止:sudo service nginx stop
重启:sudo service nginx restart
Nginx基础配置
1. 配置文件位置
主配置文件:/etc/nginx/nginx.conf
备用文件:/etc/nginx/conf.d/default.conf
(通常用于虚拟主机配置)
2. 配置格式
user nobody; # 运行用户和组 worker_processes 1; # 工作进程数 error_log /var/log/nginx/error.log; # 错误日志路径 pid /run/nginx.pid; # PID文件路径 events { worker_connections 1024; # 每个工作进程允许的最大连接数 } http { include /etc/nginx/mime.types; # MIME类型文件 default_type application/octet-stream; # 默认MIME类型 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 /var/log/nginx/access.log main; # 访问日志路径 sendfile on; # 启用sendfile传输文件 keepalive_timeout 65; # 保持连接超时时间 include /etc/nginx/conf.d/*.conf; # 包含的额外配置文件 server { listen 80; # 监听端口 server_name example.com; # 域名地址 location / { root /var/www/html; # 站点根目录 index index.html index.htm; # 默认索引文件 } } }
3. 检查和加载配置
检查语法:nginx -t
热加载配置:nginx -s reload
虚拟主机配置
1. 定义虚拟主机
在配置文件中定义多个server块,每个server块代表一个虚拟主机。
server { listen 80; # 监听端口 server_name example.com; # 域名地址 root /var/www/example.com/html; # 站点根目录 index index.html index.htm; # 默认索引文件 location / { try_files $uri $uri/ =404; # 请求处理规则 } }
2. 监听不同端口
可以为每个虚拟主机设置不同的监听端口,
server { listen 8080; # 监听8080端口 server_name another.com; # 另一个域名地址 root /var/www/another.com/html; # 站点根目录 index index.html index.htm; # 默认索引文件 }
反向代理配置
1. 反向代理原理
将客户端请求转发到后端服务器,实现负载均衡和服务器安全加固。
2. 配置示例
server { listen 80; # 监听端口 server_name example.com; # 域名地址 location / { proxy_pass http://localhost:3000; # 转发请求到本地3000端口服务 proxy_set_header Host $host; # 传递Host头信息 proxy_set_header X-Real-IP $remote_addr; # 传递真实IP头信息 proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; # 传递代理IP头信息 } }
SSL证书安装及HTTPS配置
1. SSL的重要性
加密客户端与服务器之间的通讯,确保数据安全。
2. 配置步骤
1、获取SSL证书:购买证书或使用Let’s Encrypt免费证书。
2、上传证书:将证书文件上传到服务器,如/etc/nginx/ssl
。
3、修改配置文件:添加以下内容以启用HTTPS。
server { listen 443 ssl; # 监听443端口并启用SSL server_name example.com; # 域名地址 ssl_certificate /etc/nginx/ssl/example.com.crt; # SSL证书文件路径 ssl_certificate_key /etc/nginx/ssl/example.com.key; # SSL私钥文件路径 ssl_protocols TLSv1 TLSv1.1 TLSv1.2; # SSL/TLS协议版本 ssl_ciphers 'HIGH:!aNULL:!MD5:!kEDH'; # SSL/TLS加密套件 location / { root /var/www/html; # 站点根目录 index index.html index.htm; # 默认索引文件 } }
4、重启Nginx:sudo service nginx restart
以使配置生效。
相关问题与解答
Q1:如何确保Nginx在引导时自动启动?
A1:可以使用systemctl enable nginx
命令来实现Nginx的自启动,这会在系统启动时自动执行Nginx服务。
Q2:如果我想限制Nginx的访问权限,应该如何配置?
A2:可以在Nginx配置文件中使用allow
和deny
指令来控制访问权限,例如只允许特定IP地址访问服务:
location / { allow 192.168.1.1; # 仅允许该IP访问 deny all; # 拒绝其他所有IP访问 }
以上就是关于“Nginx服务器初期基本配置指南”的问题,朋友们可以点击主页了解更多内容,希望可以够帮助大家!