CentOS 安装nginx

CentOS 安装nginx

安装使用的是配置nginx官网yum仓库安装

同时适用于Red Hat Enterprise Linux 及其衍生产品,例如 CentOS、Oracle Linux、Rocky Linux、AlmaLinux

如想使用压缩包解压方式安装请自行百度

注:安装全程使用非root用户 且 该用户已有sudo权限

安装工具包

sudo yum install yum-utils

设置yum仓库

  • 新建nginx官方yum仓库配置文件/etc/yum.repos.d/nginx.repo

  • 文件内容如下

[nginx-stable]
name=nginx stable repo
baseurl=http://nginx.org/packages/centos/$releasever/$basearch/
gpgcheck=1
enabled=1
gpgkey=https://nginx.org/keys/nginx_signing.key
module_hotfixes=true[nginx-mainline]
name=nginx mainline repo
baseurl=http://nginx.org/packages/mainline/centos/$releasever/$basearch/
gpgcheck=1
enabled=0
gpgkey=https://nginx.org/keys/nginx_signing.key
module_hotfixes=true

这个配置文件 stable代表的稳定版本(默认) mainline代表的是主线版本

切换使用主线版本 命令:sudo yum-config-manager --enable nginx-mainline

安装nginx

# 安装
sudo yum install nginx
# 启动/关闭/重载/开机自启/关闭开机自启
sudo systemctl [start/stop/reload/enable/disable] nginx# nginx相关命令
# 检查配置文件(修改nginx.conf 或 nginx/conf.d/*.conf内的内容后使用)
sudo nginx -t
# 重载配置文件(检查 提示没有问题后 重载下配置文件即可生效)
sudo nginx -s reload

配置文件说明

  • nginx配置文件(一般不修改)

/etc/nginx/nginx.conf

  • nginx配置其他域名虚拟主机的目录(新增自己网站域名时需要cp default.conf适当修改)

/etc/nginx/conf.d/

  • 默认的一些nginx html页面(一般不修改)

/usr/share/nginx/html/

  • 默认日志文件

/var/log/nginx/host.access.log

  • 个人html页面看个人喜好,一般可以放在

/var/www/域名/

新增主机域名 nginx 配置脚本

个人使用chatgpt写的仅供参考

1.在/etc/nginx/conf.d下新建temp目录

2.在上面创建的temp目录下新建http.conf.temp和https.conf.temp文件,内容如下

  • http.conf.temp
server {listen 80;server_name {{domain}};access_log /var/log/nginx/{{domain}}.access.log main;location / {root /var/www/{{domain}};index index.html index.htm;#try_files $uri $uri/ /index.html;}error_page 500 502 503 504 /50x.html;location = /50x.html {root /usr/share/nginx/html;}location ^~ /api/ {proxy_pass http://localhost:8080/;proxy_set_header Host $host;proxy_set_header X-Real-IP $remote_addr;proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;}
}
  • https.conf.temp
server {#HTTPS的默认访问端口443。#如果未在此处配置HTTPS的默认访问端口,可能会造成Nginx无法启动。listen 443 ssl;#填写证书绑定的域名server_name {{domain}};access_log  /var/log/nginx/{{domain}}.access.log  main;#填写证书文件绝对路径ssl_certificate /etc/nginx/ssl/{{domain}}/{{domain}}.pem;#填写证书私钥文件绝对路径ssl_certificate_key /etc/nginx/ssl/{{domain}}/{{domain}}.key;ssl_session_cache shared:SSL:1m;ssl_session_timeout 5m;#自定义设置使用的TLS协议的类型以及加密套件(以下为配置示例,请您自行评估是否需要配置)#TLS协议版本越高,HTTPS通信的安全性越高,但是相较于低版本TLS协议,高版本TLS协议对浏览器的兼容性较差。ssl_ciphers ECDHE-RSA-AES128-GCM-SHA256:ECDHE:ECDH:AES:HIGH:!NULL:!aNULL:!MD5:!ADH:!RC4;ssl_protocols TLSv1.1 TLSv1.2 TLSv1.3;#表示优先使用服务端加密套件。默认开启ssl_prefer_server_ciphers on; location / {root /var/www/{{domain}};index index.html index.htm;#try_files $uri $uri/ /index.html;}error_page   500 502 503 504  /50x.html;location = /50x.html {root   /usr/share/nginx/html;}location ^~ /api/ {proxy_pass http://localhost:8080/;proxy_set_header Host $host;proxy_set_header X-Real-IP $remote_addr;proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;}
}server {listen 80;#填写证书绑定的域名server_name {{domain}};#将所有HTTP请求通过rewrite指令重定向到HTTPS。rewrite ^(.*)$ https://$host$1;location / {index index.html index.htm;}
}

3.在/home/用户/bin下新增sh脚本

  • 新增主机域名脚本,名字可以自定义

    使用脚本的时候就是文件名

    该脚本执行后会自动生成/etc/nginx/conf.d/域名.conf文件和/var/www/域名/目录

    https模板使用的是阿里云的ssl证书配置

    其他供应商请自行修改/etc/nginx/conf.d/temp/https.conf.temp/etc/nginx/conf.d/域名.conf

    https不会生成证书 还需自行上传至 目录 /etc/nginx/ssl/域名/,文件名需修改为域名.pem域名.key

#!/bin/bash# 检查是否提供了所需的命令行参数
if [ "$#" -ne 2 ]; thenecho "用法: $0 <域名> <http|https>"exit 1
fi# 获取命令行参数
DOMAIN="$1"
PROTOCOL="$2"# 确定配置文件模板
if [ "$PROTOCOL" == "http" ]; thenTEMPLATE_FILE="/etc/nginx/conf.d/temp/http.conf.temp"
elif [ "$PROTOCOL" == "https" ]; thenTEMPLATE_FILE="/etc/nginx/conf.d/temp/https.conf.temp"
elseecho "错误: 无效的协议。请选择 'http' 或 'https'"exit 1
fi# 确定目录和配置文件路径
NEW_DIR="/var/www/$DOMAIN"
CONF_FILE="/etc/nginx/conf.d/$DOMAIN.conf"# 创建目录
if [ -d "$NEW_DIR" ]; thenecho "目录 $NEW_DIR 已存在。"
elsesudo mkdir -p "$NEW_DIR"echo "目录 $NEW_DIR 已创建。"
fi# 设置 Nginx 用户权限为读写执行,并设置目录的组为 Nginx 用户的组
sudo chown -R nginx:nginx "$NEW_DIR"
sudo chmod -R 755 "$NEW_DIR"# 添加用户到 Nginx 用户组
sudo usermod -aG nginx "$(whoami)"# 设置同组用户权限为读写执行
sudo chmod -R g+rwx "$NEW_DIR"echo "已为 Nginx 用户设置对 $NEW_DIR 的读写执行权限。"
echo "已为同组用户设置对 $NEW_DIR 的读写执行权限。"# 检查模板文件是否存在
if [ ! -f "$TEMPLATE_FILE" ]; thenecho "错误: 模板文件 $TEMPLATE_FILE 不存在。"exit 1
fi# 创建配置文件
if [ -f "$CONF_FILE" ]; thenecho "配置文件 $CONF_FILE 已存在。"
elsesudo cp "$TEMPLATE_FILE" "$CONF_FILE"sudo sed -i "s/{{domain}}/$DOMAIN/g" "$CONF_FILE"echo "配置文件 $CONF_FILE 已创建。"
fi# 确认权限
echo "当前目录权限:"
ls -ld "$NEW_DIR"echo "目录和权限设置完成。"
  • 删除主机域名脚本

注意:该脚本执行后会删除/var/www/域名//etc/nginx/conf.d/域名,不会删除日志信息

#!/bin/bash# 检查是否提供了所需的命令行参数
if [ "$#" -ne 1 ]; thenecho "用法: $0 <目录名称>"exit 1
fi# 获取目录名称参数
DIR_NAME="$1"
WWW_DIR="/var/www/$DIR_NAME"
CONF_FILE="/etc/nginx/conf.d/$DIR_NAME.conf"# 删除目录
if [ -d "$WWW_DIR" ]; thensudo rm -rf "$WWW_DIR"echo "目录 $WWW_DIR 已删除。"
elseecho "目录 $WWW_DIR 不存在。"
fi# 删除配置文件
if [ -f "$CONF_FILE" ]; thensudo rm "$CONF_FILE"echo "配置文件 $CONF_FILE 已删除。"
elseecho "配置文件 $CONF_FILE 不存在。"
fiecho "删除操作完成。"

4.给两个文件新增可执行权限

chmod +x 文件名

结尾

本文安装nginx都是基于nginx官网写的

新增主机域名 nginx配置脚本是个人使用chatgpt写的,可以根据自己的习惯修改

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/877877.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

[Day 62] 區塊鏈與人工智能的聯動應用:理論、技術與實踐

AI在電子商務中的應用實例 隨著人工智能(AI)技術的快速發展,它在電子商務領域的應用也日益廣泛。AI不僅能夠提高運營效率,還能為客戶提供更個性化、更智能的購物體驗。本文將探討AI在電子商務中的一些具體應用實例,並通過代碼示例來說明這些應用是如何實現的。 智能產品推薦系…

WPF—资源的使用

资源的使用 资源是可以在应用中的不同位置重复使用的对象。 资源的示例包括画笔和样式。 <Window.Resources><!--定义颜色资源--><SolidColorBrush x:Key"MyBrush" Color"#05E0E9"/><!--定义样式资源--><Style TargetType&quo…

NAT和ACL部署在进出接口作用有什么不同

NAT和ACL部署在进出接口的作用存在明显的不同&#xff0c;具体表现如下&#xff1a; NAT部署在进出接口的作用 NAT&#xff08;网络地址转换&#xff09; 主要用于实现私有IP地址与公网IP地址之间的转换。 出接口&#xff08;Outbound&#xff09; &#xff1a;当数据包从企…

uniapp在线视频监控开发

我这里是uniapp开发的H5项目 视频流是flv模式 用到的插件是flv.js Flv.js Flv.js 是 HTML5 Flash 视频&#xff08;FLV&#xff09;播放器&#xff0c;纯原生 JavaScript 开发&#xff0c;没有用到 Flash。。由 bilibili 网站开源。 常见直播协议 RTMP: 底层基于TCP&…

TinyVision 使用 SyterKit 启动 Linux 6.7 主线内核

TinyVision 使用 SyterKit 启动 Linux 6.7 主线内核 SyterKit SyterKit 是一个纯裸机框架&#xff0c;用于 TinyVision 或者其他 v851se/v851s/v851s3/v853 等芯片的开发板&#xff0c;SyterKit 使用 CMake 作为构建系统构建&#xff0c;支持多种应用与多种外设驱动。同时 Sy…

docker GBase 8sV8.8使用的常见错误

因项目需要GBase 8sV8.8数据库环境&#xff0c;所以在搭建使用过程中有一些坑和错误&#xff0c;所以记录和分享 docker搭建 docker.com获取镜像 docker pull liaosnet/gbase8s:v8.8_3503x1_x64创建容器 docker run -d -p 19088:9088 \-e SERVERNAMEgbase01 \-e USERPASSGB…

Linux 基础命令大全

Linux是一个功能强大、灵活的操作系统&#xff0c;为用户提供了稳定性、安全性和庞大的开发者和用户社区。它是个人和企业使用的流行选择。 当涉及到Linux基础命令时&#xff0c;以下是一些常用的命令及其功能介绍&#xff1a; 1.ls 查看目录 语法&#xff1a;ls [选项] [文件…

C#实现数据采集系统-数据反写(3)ModbusTcp写入数据模块开发

写入报文分析 ModbusTcp报文详细解析见 ModbusTCP协议报文解析 写入常用的四个功能码&#xff0c;线圈 05,15&#xff08;0x0F&#xff09;,寄存器06,16&#xff08;0x10&#xff09; 详细报文如下&#xff1a; //00 01 00 00 00 06 FF 05 00 01 FF 00 写单个线圈 //00 01 …

Metasploit漏洞利用系列(十):MSF渗透测试 - 震网三代(远程快捷方式漏洞)实战

在本系列的第十篇中&#xff0c;我们将深入探讨如何利用Metasploit Framework (MSF) 来利用著名的震网三代&#xff08;Stuxnet三代&#xff09;中的一个远程快捷方式漏洞&#xff08;LNK漏洞&#xff09;。虽然“震网三代”并非官方术语&#xff0c;而是为了描述一个类似震网蠕…

PHPStorm如何使用Phalcon框架的依赖

问题背景 在上一篇文章里面写的如何把Phalcon 集成到PhpStorm里面,发现有个地方讲得不是很清楚,就是在使用Phalcon开发的过程中,会发现没有Phalcon框架的代码提示,这个让人感到很难受,写代码的效率也会降低不少。当时讲得是在项目的外部库下导入依赖源, 然后在写代码的时…

Vue路由—进阶篇

文章目录 路由守卫1、 路由全局守卫全局前置守卫&#xff1a;全局后置守卫&#xff1a; 2、 路由独享守卫3、 组件内部守卫组件前置守卫&#xff1a;组件更新守卫&#xff1a;组件离开守卫&#xff1a; 路由元信息路由组件过渡特效 本篇内容讲述了更多关于 Vue路由 这方面的知识…

HTML简单了解和基础知识记录

参考视频 html的用途 超文本标记语言&#xff08;英语&#xff1a;HyperText Markup Language&#xff0c;简称&#xff1a;HTML&#xff09;&#xff0c;用来显示网页的文字和框架结构&#xff0c;可以认为是网页的骨架。 标签/元素 用于定义文字图片连接等&#xff0c;分…

前端 uniapp 多端条件编译

条件编译是用特殊的注释作为标记&#xff0c;在编译时根据这些特殊的注释&#xff0c;将注释里面的代码编译到不同平台。 使用方法 以 #ifdef 或 #ifndef 加 %PLATFORM% 开头&#xff0c;以 #ifndef 结尾。 #ifdef&#xff1a;if defined 仅在某平台存在#ifndef&#xff1a;…

MacOS上升级Ruby版本

在MacOS上升级Ruby版本是一个涉及多个步骤的过程&#xff0c;这些步骤不仅要求技术操作准确&#xff0c;还需要考虑到与项目兼容性、依赖包管理以及系统安全性等多方面的因素。以下将详细介绍MacOS上升级Ruby版本的流程、注意事项以及可能的解决方案&#xff0c;确保整个升级过…

R 语言学习教程,从入门到精通,R 绘图饼图(23)

1、R 绘图 条形图 条形图&#xff0c;也称为柱状图条形图&#xff0c;是一种以长方形的长度为变量的统计图表。 条形图可以是水平或垂直的&#xff0c;每个长方形可以有不同的颜色。 R 语言使用 barplot() 函数来创建条形图&#xff0c;格式如下&#xff1a; barplot(H,xlab,…

JavaScript初级——DOM和事件简介

一、什么是DOM&#xff1f; 二、模型 三、对象的 HTML DOM 树 四、节点 浏览器已经为我们提供了文档节点对象&#xff0c;这个对象是window属性&#xff0c;可以再网页中直接使用&#xff0c;文档节点代表的是整个网页。 五、事件简介 事件&#xff0c;就是用户和浏览器之间的交…

最短路 - BellFord算法

有边数限制&#xff0c;存在负权边 题目描述 给定一个n个点m条边的有向图&#xff0c;图中可能存在重边和自环&#xff0c;边权可能为负数。 请你求出从1号点到n号点的最多经过k条边的最短距离&#xff0c;如果无法从1号点走到n号点&#xff0c;输出impossible. 注意:图中可能…

vue3+vite+cesium配置参考

在vite项目中使用Cesium的配置 关键&#xff1a; 资源目录的复制&#xff1b;CESIUM_BASE_URL的正确配置 //vite.config.js // ... // 安装打包复制资源插件&#xff0c;手动复制不需要 // npm i vite-plugin-static-copy import { viteStaticCopy } from vite-plugin-static-c…

linux+mysql+mongo+redis基础指令一文秒懂

Linux基础指令 基础指令&#xff1a; 安装网络工具&#xff0c;终端输入&#xff1a;sudo apt install net-tools&#xff0c;可以输入ifconfig查看虚拟机Ip 2. 适配客户机分配率&#xff0c;终端输入&#xff1a;sudo apt install open-vm-tools 3. 指令格式&#xff1a;指令名…

Linux系统下的容器安全:深入解析与最佳实践

在云计算和微服务架构的推动下&#xff0c;容器技术因其高效、可移植和灵活的特点&#xff0c;已经成为现代软件开发和部署的首选方案。然而&#xff0c;容器的广泛应用也带来了新的安全挑战&#xff0c;尤其是在Linux系统下&#xff0c;容器安全的实现和维护变得尤为重要。本文…