nginx学习

nginx

安装

  1. http://nginx.org/en/download.html 下载最新稳定版,比如版本1.14.2 http://nginx.org/download/nginx-1.14.2.tar.gz, 可以自linux下执行wget http://nginx.org/download/nginx-1.14.2.tar.gz, 下载最新稳定版本。
  2. 解压缩压缩包,执行:tar -zxvf nginx-1.14.2.tar.gz
  3. cd nginx-1.14.2
  4. 安装依赖包,yum install pcre-devel openssl-devel zlib-devel
  5. 配置nginx的编译选项,指定安装目录:./configure --prefix=/usr/local/nginx --with-http_ssl_module
    --prefix选项用于设置nginx的安装目录,--with-http_ssl_module用于设置nginx中允许设置使用http_ssl_module模块的相关功能
  6. 通过make命令编译和安装nginx:make && make install &&用于连接两个命令,根据前面的命令返回值决定是否执行后面的命令,只有前面的命令成功时才会执行后面的命令。
  7. 进入到nginx可执行文件安装目录: cd /usr/local/nginx/sbin
  8. 执行nginx命令,./nginx 启动nginx
  9. 如果提示nginx: [emerg] bind() to 0.0.0.0:80 failed (98: Address already in use)。执行killall -9 nginx 关闭nginx进程。如果提示killall命令不存在,则执行yum install psmisc安装killall命令。
  10. 关闭nginx进程方式,kill nginx 主进程id 或 killall nginx
  11. nginx命令表
命令 说明
nginx -s reload 在nginx已经启动的请款下重新加载配置文件(平滑重启)
nginx -s reopen 重新打开日志文件
nginx -c /特定目录/nginx.conf 以特定目录下的配置文件启动nginx
nginx -t 检测当前配置文件是否正确
nginx -t -c /特定目录/nginx.conf 检测特定目录下的配置文件是否正确
nginx -v 显示版本信息
nginx -V 显示版本信息和编译选项
  1. 查看端口号占用,默认情况下,nginx启动后悔监听80端口,从而提供http访问,如果80端口已经被占用则会启动失败,可使用netstat -tlnp命令查看端口号占用的情况。
  2. 访问测试,默认情况下CentOs系统开启了iptables防火墙,nginx提供http访问所监听的80端口是被阻止访问的。通过下面的命令可以打开指定的端口。iptables -I INPUT -p tcp --dport 80 -j ACCEPT
    参数说明:
    -I INPUR 表示在INPUT(外部访问规则)中插入一条规则。-p tcp 指定数据包匹配的协议(tcp,udp,icmp),这里指定tcp协议。--dport 80 用于指定数据包匹配的目标端口号,这里为80端口。-j ACCEPT指定对数据包的处理操作(ACCEPT,DROP,REJECT,REDIRECT等)这里指定ACCEPT操作。

    在centos 7 中iptales提示命令不存在,需要安装iptables,通过yum install iptables-services 进行安装。

    设置开机启动:

    systemctl enable iptables

    systemctl stop iptables

    systemctl start iptables

    systemctl restart iptables

    systemctl reload iptables

    保存设置:

    service iptables save


    在CentOS 7或RHEL 7或Fedora中防火墙由firewalld来管理

    如果要添加范围例外端口 如 1000-2000

    语法命令如下:启用区域端口和协议组合

    firewall-cmd [--zone=<zone>] --add-port=<port>[-<port>]/<protocol> [--timeout=<seconds>]
    此举将启用端口和协议的组合。端口可以是一个单独的端口 <port> 或者是一个端口范围 <port>-<port> 。协议可以是 tcp 或 udp。
    实际命令如下:

    添加

    firewall-cmd --zone=public --add-port=80/tcp --permanent (--permanent永久生效,没有此参数重启后失效)

    firewall-cmd --zone=public --add-port=1000-2000/tcp --permanent

    重新载入

    firewall-cmd --reload

    查看

    firewall-cmd --zone=public --query-port=80/tcp

    删除

    firewall-cmd --zone=public --remove-port=80/tcp --permanent

    总之要打开防火墙。
  3. 添加到环境变量中。可以通过创建软链接方式将ngxin可执行程序连接到/usr/local/sbin目录中,从而创建nginx命令。操作如下:ln -s /usr/local/nginx/sbin/nginx /usr/local/sbin/nginx ln标示创建链接,-s表示软链接,后面跟两个路径,第一个为源文件路径,第二个表示目标文件路径。
  4. 系统服务,开机启动,可参考 https://blog.csdn.net/qq_36441027/article/details/80636526

    如果通过yum方式安装的nginx,已经生成了nginx.service文件,直接用命令systemctl enable nginx.service,即可添加到系统服务中。然后设置开机启动即可。上文使用编译的方式安装的,需要生成nginx.service文件。在系统服务目录下创建nginx.service文件,
    vi /lib/systemd/system/nginx.service。内容如下:
[Unit]
Description=nginx
After=network.target
  
[Service]
Type=forking
ExecStart=/usr/local/nginx/sbin/nginx
ExecReload=/usr/local/nginx/sbin/nginx -s reload
ExecStop=/usr/local/nginx/sbin/nginx -s quit
PrivateTmp=true
  
[Install]
WantedBy=multi-user.target

[Unit]:服务的说明

Description:描述服务

After:描述服务类别

[Service]服务运行参数的设置

Type=forking是后台运行的形式

ExecStart为服务的具体运行命令

ExecReload为重启命令

ExecStop为停止命令

PrivateTmp=True表示给服务分配独立的临时空间

注意:[Service]的启动、重启、停止命令全部要求使用绝对路径

[Install]运行级别下服务安装的相关设置,可设置为多用户,即系统运行级别为3

修改nginx.service权限为777,chmod -777 /usr/lib/systemd/system/nginx.service

然后执行(修改或新增文件需要执行以下语句才能生效)systemctl daemon-reload

设置开机启动: systemctl enable nginx.service

启动nginx服务:systemctl start nginx.service 

停止开机启动nginx服务:systemctl disable nginx.service 

查看nginx服务状态:systemctl status nginx.service
 
重启nginx服务:systemctl restart nginx.service 

查看所有已启动的服务:systemctl list-units --type=service

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,723评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,003评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,512评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,825评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,874评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,841评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,812评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,582评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,033评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,309评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,450评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,158评论 5 341
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,789评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,409评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,609评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,440评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,357评论 2 352

推荐阅读更多精彩内容

  • 概述 什么是 Nginx?Nginx (engine x) 是一款轻量级的 Web 服务器 、反向代理服务器及电子...
    weisen阅读 590评论 0 0
  • I/O模型: 阻塞型、非阻塞型、复用型、信号驱动型、异步 同步/异步:关注消息通知机制 消息通知:同步:等待对方返...
    Net夜风阅读 2,001评论 0 1
  • 1.什么是负载均衡?通过某种负载分担技术,将外部发送来的请求按照某种策略分配到服务器集合的某一台服务器上,而接收到...
    少艾_91df阅读 497评论 0 0
  • 基础命令 为了在 sudo 中设置权限提升,您需要编辑 sudoers 文件。 你不应该直接编辑文件,而是使用:s...
    米开朗基乐阅读 1,902评论 0 5
  • 为了为 web3j 开发者提供更高的灵活性,该项目由多个模块组成。按照依赖顺序,他们分别是: util - 实用程...
    ChainBoard链博科技阅读 627评论 0 1