• Linux-----nginx的简介,nginx搭载负载均衡以及nginx部署前后端分离项目


    目录

    nginx的简介

    是什么

    nginx的特点以及功能

    Nginx负载均衡

    下载 

    安装 

    负载均衡


    nginx的简介

    是什么

    Nginx是一个高性能的开源Web服务器和反向代理服务器。它的设计目标是为了解决C10k问题,即在同一时间内支持上万个并发连接。

    Nginx采用事件驱动的异步架构,能够高效地处理大量并发请求,同时占用较少的系统资源。它具有良好的扩展性和高可靠性,广泛应用于大型网站和高负载的Web应用中。

    nginx的特点以及功能

    1. 高性能:Nginx采用异步非阻塞的处理方式,可以高效地处理大量并发请求,具有较低的内存消耗和CPU利用率。

    2. 反向代理:Nginx可以作为反向代理服务器,将客户端的请求转发给后端的多个服务器,实现负载均衡和高可用性。

    3. 静态文件服务:Nginx可以快速地提供静态文件的访问,减轻动态应用服务器的负载。

    4. 动态反向代理:Nginx可以通过配置动态反向代理规则,将请求转发给不同的后端服务器,实现灵活的请求处理和应用切换。

    5. SSL/TLS支持:Nginx支持HTTPS协议,并提供了强大的SSL/TLS功能,可以保护网站的安全性。

    6. URL重写和重定向:Nginx支持强大的URL重写和重定向功能,可以通过配置简化URL结构和实现请求的重定向。

    7. 缓存和压缩:Nginx支持静态文件的缓存和内容的压缩,提高网站的性能和传输速度。

     总之,Nginx是一个高性能、可靠性强、功能丰富的Web服务器和反向代理服务器,适用于各种规模的网站和应用场景。它的简单配置和灵活性使得它成为许多开发者和系统管理员的首选。

    Nginx负载均衡

    下载 

    输入命令 :  cd /root/xyh/software  进入到资源文件目录

    安装 Nginx 的4个依赖

    输入命令 : yum -y install gcc zlib zlib-devel pcre-devel openssl openssl-devel

     

    安装完成后进行解压使用

    输入命令 :  tar -xvf nginx-1.13.7.tar.gz   ( 解压 Nginx)

     

    解压后进入其文件

    命令 :  cd nginx-1.13.7  

    编译,执行配置: 考虑到后续安装ssl证书 添加两个模块

    命令 : ./configure --with-http_stub_status_module --with-http_ssl_module

     

    安装 

    进行安装

    命令 :   make && make install

     

    安装完后,进入该目录

    输入命令 :  cd /usr/local/nginx

    安装完后,进入该目录

    输入命令 :  cd /usr/local/nginx

    启动前安装 lsof 命令

    输入命令 :  yum install -y  lsof

     

    设置防火墙 开放 80 端口

    输入命令 : firewall-cmd --zone=public --add-port=80/tcp --permanent

    更新防火墙的端口并且查看已开放的端口

    输入命令 :  firewall-cmd --reload && firewall-cmd --list-port

     

    # 启动

    命令 :  ./nginx

    #查看 

    命令 :  lsof -i:80

     

    在浏览器中,输入虚拟机【Linux】-Centos的IP地址进行搜索 

     以上就是Nginx 的使用配置并且开启完成了

    负载均衡

    在资源文件夹中,创建一个tomcat文件夹,来存放Tomcat
    输入命令 :  mkdir tomcat

    并且将tomcat服务解压到指定目录,刚刚创建的tomcat文件夹中。

    输入命令 : tar -xvf apache-tomcat-8.5.tar.gz -C tomcat

     

    进入tomcat文件夹中

    命令 :  cd /root/xyh/software/tomcat

    复制一个tomcat,准备2个tomcat

    命令 : cp -r apache-tomcat-8.5.20/ apache-tomcat-8.5.20_8081/

    查看命令 : ll

     

    将其中的一个tomcat修改端口,避免两个服务同时开启时端口被占用的情况。

    命令 :  cd apache-tomcat-8.5.20/conf   ( 进入到tomcat的conf文件中 )

    找到server.xml 文件进行修改端口

    命令 : vim server.xml   ( 编辑文件修改端口 ) 

     

     

     修改之后的代码

    1. <?xml version="1.0" encoding="UTF-8"?>
    2. <!--
    3. Licensed to the Apache Software Foundation (ASF) under one or more
    4. contributor license agreements. See the NOTICE file distributed with
    5. this work for additional information regarding copyright ownership.
    6. The ASF licenses this file to You under the Apache License, Version 2.0
    7. (the "License"); you may not use this file except in compliance with
    8. the License. You may obtain a copy of the License at
    9. http://www.apache.org/licenses/LICENSE-2.0
    10. Unless required by applicable law or agreed to in writing, software
    11. distributed under the License is distributed on an "AS IS" BASIS,
    12. WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
    13. See the License for the specific language governing permissions and
    14. limitations under the License.
    15. -->
    16. <!-- Note: A "Server" is not itself a "Container", so you may not
    17. define subcomponents such as "Valves" at this level.
    18. Documentation at /docs/config/server.html
    19. -->
    20. <Server port="8006" shutdown="SHUTDOWN">
    21. <Listener className="org.apache.catalina.startup.VersionLoggerListener" />
    22. <!-- Security listener. Documentation at /docs/config/listeners.html
    23. <Listener className="org.apache.catalina.security.SecurityListener" />
    24. -->
    25. <!--APR library loader. Documentation at /docs/apr.html -->
    26. <Listener className="org.apache.catalina.core.AprLifecycleListener" SSLEngine="on" />
    27. <!-- Prevent memory leaks due to use of particular java/javax APIs-->
    28. <Listener className="org.apache.catalina.core.JreMemoryLeakPreventionListener" />
    29. <Listener className="org.apache.catalina.mbeans.GlobalResourcesLifecycleListener" />
    30. <Listener className="org.apache.catalina.core.ThreadLocalLeakPreventionListener" />
    31. <!-- Global JNDI resources
    32. Documentation at /docs/jndi-resources-howto.html
    33. -->
    34. <GlobalNamingResources>
    35. <!-- Editable user database that can also be used by
    36. UserDatabaseRealm to authenticate users
    37. -->
    38. <Resource name="UserDatabase" auth="Container"
    39. type="org.apache.catalina.UserDatabase"
    40. description="User database that can be updated and saved"
    41. factory="org.apache.catalina.users.MemoryUserDatabaseFactory"
    42. pathname="conf/tomcat-users.xml" />
    43. </GlobalNamingResources>
    44. <!-- A "Service" is a collection of one or more "Connectors" that share
    45. a single "Container" Note: A "Service" is not itself a "Container",
    46. so you may not define subcomponents such as "Valves" at this level.
    47. Documentation at /docs/config/service.html
    48. -->
    49. <Service name="Catalina">
    50. <!--The connectors can use a shared executor, you can define one or more named thread pools-->
    51. <!--
    52. <Executor name="tomcatThreadPool" namePrefix="catalina-exec-"
    53. maxThreads="150" minSpareThreads="4"/>
    54. -->
    55. <!-- A "Connector" represents an endpoint by which requests are received
    56. and responses are returned. Documentation at :
    57. Java HTTP Connector: /docs/config/http.html
    58. Java AJP Connector: /docs/config/ajp.html
    59. APR (HTTP/AJP) Connector: /docs/apr.html
    60. Define a non-SSL/TLS HTTP/1.1 Connector on port 8080
    61. -->
    62. <Connector port="8081" protocol="HTTP/1.1"
    63. connectionTimeout="20000"
    64. redirectPort="8443" />
    65. <!-- A "Connector" using the shared thread pool-->
    66. <!--
    67. <Connector executor="tomcatThreadPool"
    68. port="8080" protocol="HTTP/1.1"
    69. connectionTimeout="20000"
    70. redirectPort="8443" />
    71. -->
    72. <!-- Define a SSL/TLS HTTP/1.1 Connector on port 8443
    73. This connector uses the NIO implementation. The default
    74. SSLImplementation will depend on the presence of the APR/native
    75. library and the useOpenSSL attribute of the
    76. AprLifecycleListener.
    77. Either JSSE or OpenSSL style configuration may be used regardless of
    78. the SSLImplementation selected. JSSE style configuration is used below.
    79. -->
    80. <!--
    81. <Connector port="8443" protocol="org.apache.coyote.http11.Http11NioProtocol"
    82. maxThreads="150" SSLEnabled="true">
    83. <SSLHostConfig>
    84. <Certificate certificateKeystoreFile="conf/localhost-rsa.jks"
    85. type="RSA" />
    86. </SSLHostConfig>
    87. </Connector>
    88. -->
    89. <!-- Define a SSL/TLS HTTP/1.1 Connector on port 8443 with HTTP/2
    90. This connector uses the APR/native implementation which always uses
    91. OpenSSL for TLS.
    92. Either JSSE or OpenSSL style configuration may be used. OpenSSL style
    93. configuration is used below.
    94. -->
    95. <!--
    96. <Connector port="8443" protocol="org.apache.coyote.http11.Http11AprProtocol"
    97. maxThreads="150" SSLEnabled="true" >
    98. <UpgradeProtocol className="org.apache.coyote.http2.Http2Protocol" />
    99. <SSLHostConfig>
    100. <Certificate certificateKeyFile="conf/localhost-rsa-key.pem"
    101. certificateFile="conf/localhost-rsa-cert.pem"
    102. certificateChainFile="conf/localhost-rsa-chain.pem"
    103. type="RSA" />
    104. </SSLHostConfig>
    105. </Connector>
    106. -->
    107. <!-- Define an AJP 1.3 Connector on port 8009 -->
    108. <Connector port="8010" protocol="AJP/1.3" redirectPort="8443" />
    109. <!-- An Engine represents the entry point (within Catalina) that processes
    110. every request. The Engine implementation for Tomcat stand alone
    111. analyzes the HTTP headers included with the request, and passes them
    112. on to the appropriate Host (virtual host).
    113. Documentation at /docs/config/engine.html -->
    114. <!-- You should set jvmRoute to support load-balancing via AJP ie :
    115. <Engine name="Catalina" defaultHost="localhost" jvmRoute="jvm1">
    116. -->
    117. <Engine name="Catalina" defaultHost="localhost">
    118. <!--For clustering, please take a look at documentation at:
    119. /docs/cluster-howto.html (simple how to)
    120. /docs/config/cluster.html (reference documentation) -->
    121. <!--
    122. <Cluster className="org.apache.catalina.ha.tcp.SimpleTcpCluster"/>
    123. -->
    124. <!-- Use the LockOutRealm to prevent attempts to guess user passwords
    125. via a brute-force attack -->
    126. <Realm className="org.apache.catalina.realm.LockOutRealm">
    127. <!-- This Realm uses the UserDatabase configured in the global JNDI
    128. resources under the key "UserDatabase". Any edits
    129. that are performed against this UserDatabase are immediately
    130. available for use by the Realm. -->
    131. <Realm className="org.apache.catalina.realm.UserDatabaseRealm"
    132. resourceName="UserDatabase"/>
    133. </Realm>
    134. <Host name="localhost" appBase="webapps"
    135. unpackWARs="true" autoDeploy="true">
    136. <!-- SingleSignOn valve, share authentication between web applications
    137. Documentation at: /docs/config/valve.html -->
    138. <!--
    139. <Valve className="org.apache.catalina.authenticator.SingleSignOn" />
    140. -->
    141. <!-- Access log processes all example.
    142. Documentation at: /docs/config/valve.html
    143. Note: The pattern used is equivalent to using pattern="common" -->
    144. <Valve className="org.apache.catalina.valves.AccessLogValve" directory="logs"
    145. prefix="localhost_access_log" suffix=".txt"
    146. pattern="%h %l %u %t "%r" %s %b" />
    147. </Host>
    148. </Engine>
    149. </Service>
    150. </Server>

     并且将这个服务器的页面显示内容进行修改,访问时容易分辨是哪个tomcat端口进入的

     在tomcat根目录的webapps中的ROOT目录中,找到index.jsp文件,在MobaXterm工具的左边选中这个文件,右键点击第二个进行打开文件,并且修改编辑文件。

     

    修改完之后的代码如下

    1. <%--
    2. Licensed to the Apache Software Foundation (ASF) under one or more
    3. contributor license agreements. See the NOTICE file distributed with
    4. this work for additional information regarding copyright ownership.
    5. The ASF licenses this file to You under the Apache License, Version 2.0
    6. (the "License"); you may not use this file except in compliance with
    7. the License. You may obtain a copy of the License at
    8. http://www.apache.org/licenses/LICENSE-2.0
    9. Unless required by applicable law or agreed to in writing, software
    10. distributed under the License is distributed on an "AS IS" BASIS,
    11. WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
    12. See the License for the specific language governing permissions and
    13. limitations under the License.
    14. --%>
    15. <%@ page session="false" pageEncoding="UTF-8" contentType="text/html; charset=UTF-8" %>
    16. <%
    17. java.text.SimpleDateFormat sdf = new java.text.SimpleDateFormat("yyyy");
    18. request.setAttribute("year", sdf.format(new java.util.Date()));
    19. request.setAttribute("tomcatUrl", "http://tomcat.apache.org/");
    20. request.setAttribute("tomcatDocUrl", "/docs/");
    21. request.setAttribute("tomcatExamplesUrl", "/examples/");
    22. %>
    23. <!DOCTYPE html>
    24. <html lang="en">
    25. <head>
    26. <meta charset="UTF-8" />
    27. <title><%=request.getServletContext().getServerInfo() %></title>
    28. <link href="favicon.ico" rel="icon" type="image/x-icon" />
    29. <link href="favicon.ico" rel="shortcut icon" type="image/x-icon" />
    30. <link href="tomcat.css" rel="stylesheet" type="text/css" />
    31. </head>
    32. <body>
    33. <h1>8081</h1>
    34. </body>
    35. </html>

    返回到tomcat目录,并且开其两个服务(tomcat) 

    命令:  cd apache-tomcat-8.5.20/bin  ( 进入到tomcat的bin目录中 )

     命令:  ./startup.sh   ( 开启服务 )

     

    再到 nginx的目录中

    命令:  cd /usr/local/nginx

     

    并且进入 : sbin目录

    输入 :  cd sbin

    命令 :  ./nginx -s reload   

    注 : 重新开启nginx

     

    今天就到这里了!下班下班!!!!!!!!!!!!!!!! 

  • 相关阅读:
    【云原生】Kubernetes----轻量级的现代HTTP反向代理和负载均衡器之Traefik
    腾讯云4核8G12M服务器支持多少人在线?
    【配电网优化】基于粒子群算法实现GARVER-6节点配电网络直流潮流计算附matlab代码
    算法训练 第八周
    高薪程序员&面试题精讲系列118之Session共享有哪些方案?
    学习开发一个RISC-V上的操作系统(汪辰老师) — 01-helloRVOS程序讲解
    10【桥接设计模式】
    pycharm控制STM32F103ZET6拍照并上位机接收显示(OV7670、照相机、STM32、TFTLCD)
    [C++黑马程序员笔记]P106-P112类和对象-对象特性(1)
    性能测试(基于Jmeter)
  • 原文地址:https://blog.csdn.net/m0_74934282/article/details/134168023