2023-07-10 14:55:04
# nginx笔记
# 一、安装
# 1.1、本地安装nginx
本地安装nginx 参考
https://nginx.org/en/download.html
https://blog.csdn.net/mao0523/article/details/122448599
C:\Users\Administrator>e:
E:\>cd ProgramFiles\nginx-1.16.1
// 启动
E:\ProgramFiles\nginx-1.16.1>start nginx
// 刷新
E:\ProgramFiles\nginx-1.16.1>nginx -s reload
// 停止
E:\ProgramFiles\nginx-1.16.1>nginx -s stop
E:\ProgramFiles\nginx-1.16.1>
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
报错 403 Forbidden
https://www.toutiao.com/article/6613280321607565832/
方法1、缺少index.html页面
方法2、将第一行的user www-data改为user root
1
2
3
4
5
6
2
3
4
5
6
# 1.2、常用命令
启动
sudo /usr/local/lighthouse/softwares/nginx/sbin/nginx
或
$ sudo systemctl start nginx #systemd
OR
$ sudo service nginx start #sysvinit
重载 Nginx 服务
sudo /usr/local/lighthouse/softwares/nginx/sbin/nginx -s reload
$ sudo systemctl reload nginx #systemd
或
$ sudo service nginx reload #sysvinit
停止
sudo /usr/local/lighthouse/softwares/nginx/sbin/nginx -s stop
$ sudo systemctl stop nginx #systemd
OR
$ sudo service nginx stop #sysvinit
开机自启动
$ sudo systemctl enable nginx #systemd
或
$ sudo service nginx enable #sysv init
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
查询状态
sudo /usr/local/lighthouse/softwares/nginx/sbin/nginx -t
ps -ef | grep nginx
$ sudo systemctl status nginx #systemd
或
$ sudo service nginx status #sysvinit
端口在使用
nginx: [emerg] bind() to 0.0.0.0:80 failed (98: Address already in use)
killall -9 nginx
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
2
3
4
5
6
7
8
9
10
11
12
13
14
15
docsify 使用nginx布署在私有服务器
// 安装docsify
npm i docsify-cli -g
docsify --version
docsify serve
注意问题:
将第一行的user www-data;,不管你那里是什么,统一改为user root,否则后面会出现403 forbidden.
server {
listen 8080;
server_name localhost;
location / {
root /home/lighthouse/shufaguiji/;
index index.html;
}
error_page 500 502 503 504 /50x.html;
location = /50x.html {
root html;
}
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
# 二、配置
# 2.1、基础配置
# 监听端口、缓存
server {
listen 8081;
server_name localhost;
root /home/lighthouse/vuepress-calligraphy;
location ~* \.(css|js|png|jpg|jpeg|gif|gz|svg|mp4|ogg|ogv|webm|htc|xml|woff)$
{
add_header Cache-Control no-cache;
add_header Pragma no-cache;
}
}
# xushufa.cn /home/lighthouse/vuepress-calligraphy
server {
listen 80;
server_name xushufa.cn;
root /home/lighthouse/vuepress-calligraphy;
#把http的域名请求转成https
return 301 https://$host$request_uri;
location ~* \.(css|js|png|jpg|jpeg|gif|gz|svg|mp4|ogg|ogv|webm|htc|xml|woff)$
{
add_header Cache-Control no-cache;
add_header Pragma no-cache;
}
}
server {
#SSL 访问端口号为 443
listen 443 ssl;
#填写绑定证书的域名
server_name xushufa.cn;
#证书文件名称
ssl_certificate /usr/local/lighthouse/softwares/nginx/conf/xushufa.cn_nginx/xushufa.cn_bundle.crt;
#私钥文件名称
ssl_certificate_key /usr/local/lighthouse/softwares/nginx/conf/xushufa.cn_nginx/xushufa.cn.key;
ssl_session_timeout 5m;
#请按照以下协议配置
ssl_protocols TLSv1.2 TLSv1.3;
#请按照以下套件配置,配置加密套件,写法遵循 openssl 标准。
ssl_ciphers ECDHE-RSA-AES128-GCM-SHA256:HIGH:!aNULL:!MD5:!RC4:!DHE;
ssl_prefer_server_ciphers on;
root /home/lighthouse/vuepress-calligraphy;
location ~* \.(css|js|png|jpg|jpeg|gif|gz|svg|mp4|ogg|ogv|webm|htc|xml|woff)$
{
add_header Cache-Control no-cache;
add_header Pragma no-cache;
}
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
日志格式化
日志格式化参考 https://blog.csdn.net/weixin_48981270/article/details/117720037
log_format json '{"timestamp":"$time_iso8601",'
'"host": "$server_addr",'
'"client": "$remote_addr",'
'"size": $body_bytes_sent,'
'"responsetime": $request_time,'
'"domain": "$host",'
'"url":"$request_uri",'
'"referer": "$http_referer",'
'"agent": "$http_user_agent",'
'"status": "$status",'
'"x_forwarded_for": "$http_x_forwarded_for"}';
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
2
3
4
5
6
7
8
9
10
11
12
13
14
15
# 2.2、日志按天保存
#!/bin/bash
# 日志按天保存
# 测试 /bin/sh /usr/local/lighthouse/softwares/nginx/sbin/cut_nginx_logs.sh
#access.log日志存放路径
log_dir="/usr/local/lighthouse/softwares/nginx/logs/"
log_name="access"
name_current_log=${log_dir}${log_name}.log
name_yesterday_log=${log_dir}${log_name}-$(date -d "yesterday" +"%Y-%m-%d").log
#复制新日志
cp $name_current_log $name_yesterday_log
#清空原日志
cat /dev/null > $name_current_log
#nginx的sbin存放路径
nginx_sbin="/usr/local/lighthouse/softwares/nginx/sbin/nginx"
echo $name_yesterday_log
#restart nginx
$nginx_sbin -s reload
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
/bin/sh^M: bad interpreter:没有那个文件或目录解决
因为操作系统是windows,我在windows下编辑的脚本,所以有可能有不可见字符。
脚本文件是DOS格式的, 即每一行的行尾以\n\r来标识, 其ASCII码分别是0x0D, 0x0A.
vim filename
然后用命令
:set ff? #可以看到dos或unix的字样. 如果的确是dos格式的。
然后用
:set ff=unix #把它强制为unix格式的, 然后存盘退出。
再次运行脚本。
https://blog.csdn.net/ywb201314/article/details/51909976
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
2
3
4
5
6
7
8
9
10
11
12
13
14
15
#打开定时任务
crontab -e
#添加定时任务
00 00 * * * /bin/sh /usr/local/lighthouse/softwares/nginx/sbin/cut_nginx_logs.sh
#":wq"保存并退出
#查看定时任务,就会看到你添加的内容了
crontab -l
1
2
3
4
5
6
7
8
9
10
2
3
4
5
6
7
8
9
10
crontab说明:
分钟 小时 日 月 星期 命令
* * * * * *
第1列表示分钟1~59 每分钟用*或者 */1表示
第2列表示小时1~23(0表示0点)
第3列表示日期1~31
第4列 表示月份1~12
第5列标识号星期0~6(0表示星期天)
第6列要运行的命令
https://blog.csdn.net/sukangshen/article/details/78900147
https://blog.csdn.net/fangyuying128825/article/details/71600969
http://www.cnblogs.com/peida/archive/2013/01/08/2850483.html
/etc/crontab
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19