首页 > 系统相关 >nginx+keepalived实现高可用

nginx+keepalived实现高可用

时间:2024-10-18 09:49:45浏览次数:9  
标签:可用 keepalived server nginx usr conf local proxy

在之前的文章已经提到怎么实现keepalived的双机热备,现在我们就结合nginx来实现高可用

1、nginx的部署

1.1 依赖安装

在线安装依赖

yum -y install gcc gcc-c++ pcre pcre-devel zlib zlib-devel openssl openssl-devel

1.2nginx的安装

https://nginx.org/en/download.html

下载好之后放到/usr/下进行解压

tar -zxvf  nginx-1.23.1.tar.gz
cd  nginx-1.23.1/ 

1.3nginx配置

echo  "export PATH=$PATH:/usr/local/nginx/sbin"  >> /etc/profile
source   /etc/profile
echo "/usr/local/nginx/sbin/nginx"  >>  /etc/rc.local
chmod 777  /etc/rc.local    /etc/rc.d/rc.local

1.4命令汇总

/usr/local/nginx/sbin/nginx  #启动
/usr/local/nginx/sbin/nginx -s stop  #停止
/usr/local/nginx/sbin/nginx -s reload   #重启
/usr/local/nginx/sbin/nginx -t   #验证
ps -ef | grep nginx  #查看进程
/usr/local/nginx/sbin/nginx -V  #查看安装模块

1.5生成自签证书

mkdir  /usr/local/nginx/ssl_cert

cd  /usr/local/nginx/ssl_cert

openssl genrsa -out server.key 2048 
#创建证书密钥文件

openssl req -new -key server.key -out server.csr
#利用密钥生成证书请求文件,按提示输入证书信息(密码为空)  全部默认回车
Country Name #名称
State or Province Name #省份
Locality Name  #城市名称
Organization Name  #单位名称
Organizational Unit  #部门
Common Name  #名称
Email Address  #邮箱
A challenge password  #私钥保护密码
An optional company name  #可选的公司名称

openssl x509 -req -days 3650 -in server.csr -signkey server.key -out server.crt    
#利用证书请求文件生成自签证书

2nginx的代理实现

前面已经把包放到/usr目录下解压,修改一下名字,改为nginx。然后再把/usr/nginx/conf/nginx.conf,全部替换

# For more information on configuration, see:
#   * Official English Documentation: http://nginx.org/en/docs/
#   * Official Russian Documentation: http://nginx.org/ru/docs/

#user nginx;
worker_processes auto;
#error_log /data/log/nginx/error.log;
#pid /run/nginx.pid;

events {
    worker_connections 10240;
}

http {
    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;
    tcp_nopush          on;
    tcp_nodelay         on;
    keepalive_timeout   65;
    types_hash_max_size 2048;
    server_tokens       off;

    include             /usr/nginx/conf/mime.types;
    default_type        application/octet-stream;
    
    include             /usr/nginx/conf/conf.d/test1.conf;
    include             /usr/nginx/conf/conf.d/test2.conf;
}

 替换完之后在/usr/nginx/conf/目录下创建一个conf.d文件夹

在conf.d文件夹下创建test1.conf和test2.conf文件来简述两种代理

vi  test1.conf

#复制下列

server {
    listen 8888;

    location / {
        proxy_set_header Host $host:$server_port; 
        proxy_set_header X-Real-IP $remote_addr; 
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; 
        proxy_set_header X-Forwarded-Proto $scheme; 
        client_max_body_size    10m;
        client_body_buffer_size 128k;
        proxy_buffer_size       4k;
        proxy_buffers           4 32k;
        proxy_busy_buffers_size 64k;
        proxy_temp_file_write_size 64k;
        proxy_connect_timeout   30;
        proxy_send_timeout      60;
        proxy_read_timeout      300;
        proxy_pass https://center.mkeysec.net/; #该地方的域名地址为被代理地址
    }
}

vi  test2.conf


#复制下列

#nginx做负载均衡,按照不同权重分配业务
#upstream device {
#   server 192.168.1.236:8080 weight=2;
#   server 192.168.1.237:8080 weight=1;
#}

upstream device {
   server 192.168.1.236:8080;
}


server {
    listen *:8443 ssl;
    ssl_certificate /usr/local/nginx/ssl_cert/server.crt; 
    ssl_certificate_key /usr/local/nginx/ssl_cert/server.key; 
    ssl_session_timeout  5m; 
    ssl_protocols TLSv1 TLSv1.1 TLSv1.2; 
    ssl_ciphers  HIGH:!aNULL:!MD5:!3DES; 
    ssl_prefer_server_ciphers  on; 

    location / {
        proxy_set_header Host $host:$server_port; 
        proxy_set_header X-Real-IP $remote_addr; 
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; 
        proxy_set_header X-Forwarded-Proto $scheme; 
		add_header Content-Security-Policy upgrade-insecure-requests; #这里是处理https反向代理http静态资源的关键
        client_max_body_size    10m;
        client_body_buffer_size 128k;
        proxy_buffer_size       4k;
        proxy_buffers           4 32k;
        proxy_busy_buffers_size 64k;
        proxy_temp_file_write_size 64k;
        proxy_connect_timeout   30;
        proxy_send_timeout      60;
        proxy_read_timeout      300;
        proxy_pass http://device/; 
		proxy_redirect  http://   https://;             #修改response中的location中的协议http为https外网访问的协议
    }



	
	####如果是代理云服务模式,可参考以下回调配置方法,不需要则删除
	
	#代理内网回调地址
	#若本监听端口的外网地址为:https://192.168.1.123:333/
	location ^~ /back/ {
        if ($request_uri ~ /back/(.*)){
            set $backurl $1;
        }
        proxy_pass $backurl;
    }

}

在test2.conf中,把下面两个ip换成我们弄的双机热备虚拟ip就能实现四台设备处理业务了。

标签:可用,keepalived,server,nginx,usr,conf,local,proxy
From: https://blog.csdn.net/m0_74766687/article/details/143016431

相关文章

  • Hadoop3.X高可用环境搭建
    目录一.基础环境准备1.角色分配2.准备软件源3.部署JDK环境4.配置host文件解析5.配置ssh免密登录6.编写data_rsync.sh同步脚本二.安装zookeeper环境1.zookeeper集群的节点数量选择2.下载zookeeper软件3.解压软件包4.配置环境变量5.准备配置文件6.同步数据7.生成myid文件8.启动zooke......
  • Lnmp(mysql分离)(nginx 1.13.6+mysql5.5+php5.3)环境一键搭建
    Lnmp(mysql分离)(nginx 1.13.6+mysql5.5+php5.3)环境一键搭建如果对运维课程感兴趣,可以在b站上、csdn或微信视频号上搜索我的账号:运维实战课程,可以关注我,学习更多免费的运维实战技术视频在192.168.37.128服务器上:(mysql只到makeinstall即可)nginx默认站点html1.上传lnmp的安装......
  • k8s多master节点配置高可用
    你们集群的master是单master还是多master多master是如何建立高可用的?负载均衡器(LoadBalancer):通过使用负载均衡器,如Nginx或HAProxy,可以实现对kube-apiserver的负载均衡和反向代理。这确保了客户端请求可以均匀地分配到多个Master节点上。Keepalived:使用Keepalived软件......
  • Nginx UI:全新的 Nginx 在线管理平台
    https://www.cnblogs.com/Can-daydayup/p/18468541 思维导航前言工具介绍主要功能支持语言在线演示开源地址程序员常用的工具软件前言Nginx在程序部署中扮演着至关重要的角色,其高性能、高安全性、易于配置和管理的特点,使得它成为现代Web应用部署中不可或缺的一部......
  • NGINX 的 Event Loop
    NGINX的EventLoop讲解NGINX的事件驱动架构基于EventLoop,它使得NGINX能够高效地处理大量并发连接,而不必为每个请求启动一个独立的线程或进程。通过EventLoop,NGINX采用非阻塞I/O模型,这样即使处理大量连接,也能保持较低的资源消耗。为什么NGINX使用EventLoo......
  • CitrixSQL Server 2016高可用之SQL镜像 SQL Server mirror 带见证服务器
    CitrixSQLServer2016高可用之SQL镜像SQLServermirror带见证服务器原来写过SQL-2008的镜像教程,时过境迁,现在流行2016了,当然也是因为自己常常用到这个功能,写下来SQL的镜像方法帮助不会的朋友。这个教程对于SQL2008\2012\2016以及2017都是可用的。三台SQL服务器,都安装好SQL软......
  • CentOS 7 下 yum 安装和配置 Nginx
    CentOS7下yum安装和配置Nginx 前言Nginx(enginex)是一个高性能的HTTP和反向代理服务器,也是一个IMAP/POP3/SMTP服务器。。本例演示CentOS7下安装和配置Nginx的基本步骤。环境说明CentOS7(MinimalInstall)$cat/etc/redhat-releaseCentOSLinuxrelea......
  • 2024 最新 jetbrains GoLand 2024.1.6 激活(亲测可用)
    注意:接下来本文分享免费激活 GoLand 等Jetbrains全家桶工具,一直支持到最新版本2024.1.6。 1.下载安装IDEA (mac、window、linux都支持)大家直接在官网下载最新版本,登陆官网,下载最新版本2024.1.4。一步一步确定安装,然后打开这里提示输入激活码,先关闭应用!!!2.下载激活工具......
  • 2024 最新 jetbrains DataGrip 2024.1.6 激活(亲测可用)
    注意:接下来本文分享免费激活 IDEA 等Jetbrains全家桶工具,一直支持到最新版本2024.1.6。 1.下载安装IDEA (mac、window、linux都支持)大家直接在官网下载最新版本,登陆官网,下载最新版本2024.1.4。一步一步确定安装,然后打开这里提示输入激活码,先关闭应用!!!2.下载激活工具打......
  • 2024 最新 jetbrains PyCharm 2024.1.6 激活(亲测可用)
    注意:接下来本文分享免费激活 PyCharm等Jetbrains全家桶工具,一直支持到最新版本2024.1.6。 1.下载安装IDEA (mac、window、linux都支持)大家直接在官网下载最新版本,登陆官网,下载最新版本2024.1.4。一步一步确定安装,然后打开这里提示输入激活码,先关闭应用!!!2.下载激活工具......