热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Nginx系列(一)——快速入门Nginx

引言Nginx是十分轻量级的开源、高性能、高可靠的HTTP和反向代理服务器,性能是Nginx最重要的考量,其占用内存少、处理高并发能力是十分强大的&#x

引言

Nginx 是十分轻量级的开源高性能高可靠HTTP和反向代理服务器,性能是 Nginx 最重要的考量,其占用内存少、处理高并发能力是十分强大的,能支持高达 5w 个并发连接数,最重要的是,Nginx 是免费的并可以商业化,配置使用也比较简单


文章目录

  • 一、Nginx基础扫盲
    • Nginx的发行版本
    • Nginx的功能和特性
    • Nginx 的缺点
  • 二、Nginx安装与配置
    • step1.Linux环境检查
    • step2.安装Nginx
    • step3.启动Nginx服务
  • 三、安装的其他问题
    • 防火墙问题导致无法访问Nginx
    • 附:其他安装方式
    • 注册Nginx为开机自启动的系统服务
  • 四、初识Nginx架构
    • Nginx.conf最小配置文件详解
    • server块的说明
      • 全局 server 块
      • location 块
      • proxy_pass
      • index
  • 五、虚拟主机和云服务器
    • 辨析虚拟主机与云服务器
    • 云服务器的一个简单使用场景
      • 当你在浏览器中输入一个url时, 到页面展示到底发生了什么?
    • Nginx配置多站点——超详细
  • 六、Nginx基础命令


一、Nginx基础扫盲

Nginx的发行版本

和Linux一样,Nginx有一些常用的发行版,我们来看一下,本文主要是对Nginx开源版本的学习

  • Nginx开源版

    简单的web服务器、反向代理、负载均衡

  • Nginx 商业版

    把Nginx和Lua脚本进行了一个整合,对微服务和云原生整合较好

  • openResty——免费开源

    OpenResty是一个基于 Nginx 与 Lua 的高性能 Web 平台,其内部集成了大量精良的 Lua 库、第三方模块以及大多数的依赖项。用于方便地搭建能够处理超高并发、扩展性极高的动态 Web 应用、Web 服务和动态网关

  • Tengine——免费开源

    Tengine是由淘宝网发起的Web服务器项目。它在Nginx的基础上,针对大访问量网站的需求,添加了很多高级功能和特性。Tengine的性能和稳定性已经在大型的网站如淘宝网,天猫商城等得到了很好的检验。它的最终目标是打造一个高效、稳定、安全、易用的Web平台。


Nginx的功能和特性


Nginx有以下三个基础功能,本文主要做到快速上手Nginx,这些功能会在其他篇章详细整理


  • 可以作为静态页面的 web 服务器
  • 反向代理
  • 负载均衡

Nginx 做为 HTTP 服务器,有以下几项基本特性:


  • 支持热部署,几乎可以做到 7 * 24 小时不间断运行,即使运行几个月也不需要重新启动,还能在不间断服务的情况下对软件版本进行热更新
  • Nginx 以事件驱动的方式编写,有非常好的性能,同时可以做非常高效的反向代理、负载均衡服务器了

  • 处理静态文件,索引文件以及自动索引;打开文件描述符缓冲.
  • 无缓存的反向代理加速,简单的负载均衡和容错.
  • FastCGI,简单的负载均衡和容错

Nginx 的缺点


  • Nginx 仅能支持http、https和Email协议,这样就在适用范围上面小些

  • 对后端服务器的健康检查,只支持通过端口来检测,不支持通过 url来检测。不支持 Session 的直接保持,但能通过 ip_hash 来解决


二、Nginx安装与配置

一般使用解压包方式安装,也是我们主要使用的安装方式,另外可以通过yum命令安装(下文有提到)

step1.Linux环境检查

Loki以后都将在Linux环境下学习整理,因此你需要有一定的Linux基础,不用担心,Loki在写这篇文章时对Linux也是一知半解的状态

请自行准备好一个可以连通网络的虚拟机并且搭载CentOS7系统,你可以通过

  • VMWare虚拟机搭建CentOS7环境

  • 购买云服务器,装载CentOS7镜像

    推荐阅读搭建云服务器Linux学习环境

除此之外,我们需要安装XShellXftp这两款软件用于控制远端服务器

安装Nginx前,我们要先安装好它的依赖环境,就像Java程序需要运行在JVM上一样,nginx安装依赖以下环境,因此要检查是否安装,如果没有则需要安装这些环境

  • GCC

    GCC编译器是Linux下最常用的C/C++编译器,它以gcc命令的形式呈现

  • openssl-devel

    openssl是多功能命令工具,用于生成密钥,创建数字证书,手动加密解密数据
    nginx 不仅支持 http 协议,还支持 https(即在ssl协议上传输http),所以需要在 Centos 安装 OpenSSL 库

  • pcre-devel

    PCRE(Perl Compatible Regular Expressions)是一个轻量级的Perl函数库,包括 perl 兼容的正则表达式库。它比Boost之类的正则表达式库小得多。PCRE十分易用,同时功能也很强大,性能超过了POSIX正则表达式库和一些经典的正则表达式库

  • zlib-devel

    zlib是提供数据压缩用的函式库,由Jean-loup Gailly与Mark Adler所开发,初版0.9版在1995年5月1日发表。zlib使用DEFLATE算法,最初是为libpng函式库所写的,后来普遍为许多软件所使用。此函式库为自由软件,使用zlib授权。截至2007年3月,zlib是包含在Coverity的美国国土安全部赞助者选择继续审查的开源项目



  1. gcc安装

    检查是否安装

    gcc --version

    已安装会显示版本号,未安装执行在线安装指令

    yum install gcc-c++

  2. PCRE 安装

    查看是否安装

    rpm -qa pcre

    已安装会显示版本号,未安装执行在线安装指令

    yum install -y pcre pcre-devel

  3. zlib 安装

    查看是否安装

    yum list installed | grep zlib*

    已安装会显示版本号,未安装执行在线安装指令

    yum install -y zlib zlib-devel

以上环境没有问题之后,我们来安装Nginx

step2.安装Nginx

官方下载地址:http://nginx.org/en/download.html

image-20220426172024670

在本机下载以后通过xftp上传到Linux服务器,执行以下命令

命令功能
./configure --prefix=/usr/local/nginx配置Nginx环境
make编译
make install安装

安装完nginx后,会在路径 /usr/local 下生成 nginx 文件夹

进入这个目录

cd /usr/local/nginx

ls查看目录结构,建议自行去看看这些文件夹

  • sbin目录(里面有两个文件:nginx nginx.old)
  • conf目录,Nginx的配置文件目录,其中**nginx.conf**是主配置文件

image-20220426223005186

step3.启动Nginx服务

#进入nginx下的sbin目录
cd /usr/local/nginx/sbin
#启动Nginx服务,./表示是当前目录
./nginx

如果访问你的Linux主机的ip地址能看到这个界面,说明Nginx服务启动成功

image-20220426223307823

三、安装的其他问题

防火墙问题导致无法访问Nginx

🚀 因为防火墙问题,在 windows 系统中访问 linux 中 nginx,默认不能访问的

因此需要开放入口规则,即开放80 端口,操作如下

查看开放的端口号

firewall-cmd --list-all

设置开放的端口号

firewall-cmd --add-service=http –permanent
firewall-cmd --add-port=80/tcp --permanent

重启防火墙

firewall-cmd –reload

redis.conf可以看到Nginx默认的监听端口

image-20220426224718318

附:其他安装方式


Windows下安装Nginx


  1. 下载windows版本

  2. 启动Nginx,直接双击nginx.exe即可

  3. 检查nginx是否启动成功

    直接在浏览器地址栏输入网址 http://localhost:80 回车,出现Nginx页面说明启动成功!


yum命令安装

一般都使用源码编译安装,很少采用yum安装

[root@centos-81 ~]# yum install -y gcc gcc-c++ pcre pcre-devel zlib zlib-devel openssl openssl-devel
[root@centos-81 ~]# useradd -u 8080 -M -s /sbin/nologin nginx
[root@centos-81 ~]# cd /usr/local/src/ ; wget https://nginx.org/download/nginx-1.14.2.tar.gz
[root@centos-81 src]# tar -xf nginx-1.14.2.tar.gz
[root@centos-81 src]# cd nginx-1.14.2/
[root@centos-81 nginx-1.14.2]# ./configure --prefix=/opt/apps/nginx --user=nginx --group=nginx
[root@centos-81 nginx-1.14.2]# make -j 4 && make install

注册Nginx为开机自启动的系统服务


首先编写自启动脚本

# 进入系统服务目录
cd /usr/lib/systemd/system
#创建nginx.service文件,并编辑
vim nginx.service

进入编辑模式,复制以下内容

[Unit]
Description=nginx service
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

然后就是配置自启动了

#重启系统服务
systemctl daemon-reload#查看当前Redis状态
ps -ef | gref nginx#如果Redis处于启动状态,关闭该服务
cd /usr/local/nginx/sbin
./nginx -s stop#根据系统服务启动 Nginx,不用到 nginx/sbin目录下启动了
systemctl start nginx

#查看进程状态,到这一步,如果Redis显示正在运行中,说明配置文件编写成功
systemctl status nginx

设置Nginx服务开机自启动

systemctl enable nginx.service

如果不想开机自启动了,可以使用下面的命令取消开机自启动

systemctl disable nginx

四、初识Nginx架构

Nginx.conf最小配置文件详解

#开头的表示注释内容,去掉所有注释内容,精简之后的内容Loki做了详细注释

#配置文件开始到 events 块之间的内容,主要设置一些影响nginx服务器整体运行的配置指令
#Nginx是多进程的(一个主进程和多个副进程),这个参数表明了开启一个副进程,worker_processes值越大,可支持的并发处理量也越多,主要受当前服务器物理CPU内核数制约
worker_processes 1;#enents块:涉及的指令主要影响 Nginx 服务器与用户的网络连接
events {#表示每个 work process 支持的最大连接数为 1024,这部分的配置对 Nginx 的性能影响较大,在实际中应该灵活配置。worker_connections 1024;
}#http块:包括 http全局部分、server 部分
http {#引入其他配置文件,便于后期维护管理与协同工作下死锁的问题include mime.types; #服务器返回文件类型,否则客户端不知道返回的数据是什么类型#如果返回类型在mime.type中没有,则返回默认类型application/octet-streamdefault_type application/octet-stream; #简单理解免除了数据传输中拷贝的过程,在调优中详细解释sendfile on;#先简单理解为保持连接超时时间,在反向代理中详解keepalive_timeout 65;#server 块:Nginx 服务器配置中最频繁的部分,代理、缓存和日志定义等绝大多数功能和第三方模块的配置都在这里#一个server代表一个虚拟主机 vhost,下文中有详解server {#当前主机监听端口号listen 80;#填写主机名或者域名,涉及到域名解析,下文详解#可以理解为在浏览器请求localhost的80端口到达这个虚拟主机server_name localhost; #一个 server 块可以配置多个 location 块,这块的主要作用是基于 Nginx 服务器接收到的请求字符串,对虚拟主机名称之外的字符串进行匹配,对特定的请求进行处理#例如对于localhost/userInfo,匹配的就是 /userInfolocation / { root html;index index.html index.htm;}#错误页服务器错误重定向地址error_page 500 502 503 504 /50x.html; location = /50x.html {root html;} }
}

server块的说明

server {listen 80; server_name Loki.com;location / {#设置被代理服务器的地址。可以是主机名称、IP地址加端口号的形式proxy_pass http://127.0.0.1:8080;index index.html index.htm index.jsp;}}

这块和虚拟主机有密切关系,虚拟主机从用户角度看,和一台独立的硬件主机是完全一样的,该技术的产生是为了节省互联网服务器硬件成本,详情请见本文下方的虚拟主机与域名绑定

每个 http 块可以包括多个 server 块,而每个 server 块就相当于一个虚拟主机。而每个 server 块也分为全局 server 块,以及可以同时包含多个 locaton 块。

全局 server 块


  • 最常见的配置是本虚拟机主机的监听配置和本虚拟主机的名称或IP配置

详细字段的解释

listen:该指令用于配置网络监听。主要有如下三种配置语法结构

一、配置监听的IP地址

listen address[:port] [default_server] [setfib=number] [backlog=number] [rcvbuf=size] [sndbuf=size] [deferred]
[accept_filter=filter] [bind] [ssl];

二、配置监听端口

listen port[default_server] [setfib=number] [backlog=number] [rcvbuf=size] [sndbuf=size] [accept_filter=filter] [deferred] [bind] [ipv6only=on|off] [ssl];

三、配置 UNIX Domain Socket

listen unix:path [default_server] [backlog=number] [rcvbuf=size] [sndbuf=size] [accept_filter=filter]
[deferred] [bind] [ssl];

上面的配置看似比较复杂,其实使用起来是比较简单的:

1 listen *:80 | *:8080 #监听所有80端口和8080端口
2 listen IP_address:port #监听指定的地址和端口号
3 listen IP_address #监听指定ip地址所有端口
4 listen port #监听该端口的所有IP连接

分别解释每个选项的具体含义:

1、address:IP地址,如果是 IPV6地址,需要使用中括号[] 括起来,比如[fe80::1]等。

2、port:端口号,如果只定义了IP地址,没有定义端口号,那么就使用80端口。

3、path:socket文件路径,如 var/run/nginx.sock等。

4、default_server:标识符,将此虚拟主机设置为 address:port 的默认主机。(在 nginx-0.8.21 之前使用的是 default 指令)

5、setfib=number:Nginx-0.8.44 中使用这个变量监听 socket 关联路由表,目前只对 FreeBSD 起作用,不常用。

6、backlog=number:设置监听函数listen()最多允许多少网络连接同时处于挂起状态,在 FreeBSD 中默认为 -1,其他平台默认为511.

7、rcvbuf=size:设置监听socket接收缓存区大小。

8、sndbuf=size:设置监听socket发送缓存区大小。

9、deferred:标识符,将accept()设置为Deferred模式。

10、accept_filter=filter:设置监听端口对所有请求进行过滤,被过滤的内容不能被接收和处理,本指令只在 FreeBSD 和 NetBSD 5.0+ 平台下有效。filter 可以设置为 dataready 或 httpready 。

11、bind:标识符,使用独立的bind() 处理此address:port,一般情况下,对于端口相同而IP地址不同的多个连接,Nginx 服务器将只使用一个监听指令,并使用 bind() 处理端口相同的所有连接。

12、ssl:标识符,设置会话连接使用 SSL模式进行,此标识符和Nginx服务器提供的 HTTPS 服务有关

server_name:该指令用于虚拟主机的配置,通常分为以下两种

1、基于名称的虚拟主机配置

语法格式如下:

server_name name ...;

一、对于name 来说,可以只有一个名称,也可以有多个名称,中间用空格隔开。而每个名字由两段或者三段组成,每段之间用“.”隔开。

server_name 123.com www.123.com

二、可以使用通配符“*”,但通配符只能用在由三段字符组成的首段或者尾端,或者由两端字符组成的尾端。

server_name *.123.com www.123.*

三、还可以使用正则表达式,用“~”作为正则表达式字符串的开始标记。

server_name ~^www\d+\.123\.com$;

该表达式“”表示匹配正则表达式,以www开头(“^”表示开头),紧跟着一个09之间的数字,在紧跟“.123.co”,最后跟着“m”($表示结尾)

以上匹配的顺序优先级如下:

1 ①、准确匹配 server_name
2 ②、通配符在开始时匹配 server_name 成功
3 ③、通配符在结尾时匹配 server_name 成功
4 ④、正则表达式匹配 server_name 成功

2、基于 IP 地址的虚拟主机配置

语法结构和基于域名匹配一样,而且不需要考虑通配符和正则表达式的问题。

server_name 192.168.1.1

location 块

该指令用于匹配 URL,地址定向、数据缓 存和应答控制等功能,还有许多第三方模块的配置也在这里进行

语法如下

location [ = | ~ | ~* | ^~] uri {}

1、= :用于不含正则表达式的 uri 前,要求请求字符串与 uri 严格匹配,如果匹配成功,就停止继续向下搜索并立即处理该请求。

2、~:用于表示 uri 包含正则表达式,并且区分大小写。

3、~*:用于表示 uri 包含正则表达式,并且不区分大小写。

4、^~:用于不含正则表达式的 uri 前,要求 Nginx 服务器找到标识 uri 和请求字符串匹配度最高的 location 后,立即使用此 location 处理请求,而不再使用 location 块中的正则 uri 和请求字符串做匹配。

注意:如果 uri 包含正则表达式,则必须要有 ~ 或者 ~ 标识*

proxy_pass

该指令用于设置被代理服务器的地址。可以是主机名称、IP地址加端口号的形式。

语法结构如下:

proxy_pass URL;

URL 为被代理服务器的地址,可以包含传输协议、主机名称或IP地址加端口号,URI等。

proxy_pass http://www.123.com/uri;

index

该指令用于设置网站的默认首页。

语法为:

index filename ...;

后面的文件名称可以有多个,中间用空格隔开。

index index.html index.jsp;

通常该指令有两个作用:第一个是用户在请求访问网站时,请求地址可以不写首页名称;第二个是可以对一个请求,根据请求内容而设置不同的首页

五、虚拟主机和云服务器

辨析虚拟主机与云服务器


虚拟主机和云服务器简介


  • 虚拟主机是一种在单一服务器或服务器群上,完成多网域服务项目的方式,虚拟主机就是把一台物理服务器划分系统资源成为多个虚拟服务器

  • 云服务器ECS(Elastic Compute Service)是在群集服务器上虚似独立服务器,每一个ECS上都是一个独立的镜像系统,提高了服务器的安全性可靠性


目前来看,虚拟主机已经退出了市场,并被云服务器所取代,原因如下


  • 虚拟主机是很多网站共用IP,这样的话很容易受到彼此的影响。而云服务器是完全独立的IP,也就不用共享IP,能避免很多麻烦
  • 虚拟主机的资源也是大家一起用的,其实使用虚拟主机根本无法享受正常资源,如果遇到很多人抢占系统资源,那么你的网站就很容易出现不稳定、卡顿等状况,有时甚至影响到业务的开展。但云服务器是独享型,它与虚拟主机不一样,云服务器能够独享硬件服务器的独立线程,并且无CPU的限制,也没有争抢,就不会出现上述状况
  • 虚拟主机容易出现权限不足的情况

云服务器的一个简单使用场景

开发者可以租用虚拟主机或者云服务器,以供用户放置站点及应用组件,提供必要的数据存放和传输功能

🐇现在基本都是买阿里云腾讯云之类的云服务器了,按需购买,还有教育优惠多合适啊

用户在浏览器输入域名,被DNS服务器解析为IP地址,访问应用服务器上,基于http协议,服务器把数据报文返回,报文内容可能是网页、视频、图片等格式,被客户端解析

注意:客户端是无法通过后缀名识别文件究竟是什么的,需要WEB服务器给它说明

例如Nginx做web服务器的话,上文Nginx.conf中include mime.types;这个字段,就是Nginx作为web服务器时向前端说明它返回了什么信息


当你在浏览器中输入一个url时, 到页面展示到底发生了什么?

🐰 附:当你在浏览器中输入一个url时, 到页面展示到底发生了什么?

  1. url指定的请求一旦发起,浏览器首先要做的事情就是解析这个域名,一般来说,浏览器会首先查看本地硬盘的 hosts 文件,看看其中有没有和这个域名对应的规则,如果有的话就直接使用 hosts 文件里面的 ip 地址

    本机hosts文件:进入C:\Windows\System32\drivers\etc目录,打开 hosts 文件,该文件指定了本机的ip映射规则

    如下所示,你可以自行指定ip地址和域名的映射关系

    # For example:102.54.94.97 loki.com # 注释内容38.25.63.10 oliverloki.com # 注释内容

  2. 如果在本地的 hosts 文件没有能够找到对应的 ip 地址,浏览器会发出一个 DNS请求到本地DNS服务器 。本地DNS服务器一般都是你的网络接入服务器商提供,比如中国电信,中国移动。

  3. 查询你输入的网址的DNS请求到达本地DNS服务器之后,本地DNS服务器会首先查询它的缓存记录,如果缓存中有此条记录,就可以直接返回结果,此过程是递归的方式进行查询。如果没有,本地DNS服务器还要向DNS根服务器进行查询。

  4. 根DNS服务器没有记录具体的域名和IP地址的对应关系,而是告诉本地DNS服务器,你可以到域服务器上去继续查询,并给出域服务器的地址。这种过程是迭代的过程。

  5. 本地DNS服务器继续向域服务器发出请求,在这个例子中,请求的对象是.com域服务器。.com域服务器收到请求之后,也不会直接返回域名和IP地址的对应关系,而是告诉本地DNS服务器,你的域名的解析服务器的地址。

  6. 最后,本地DNS服务器向域名的解析服务器发出请求,这时就能收到一个域名和IP地址对应关系,本地DNS服务器不仅要把IP地址返回给用户电脑,还要把这个对应关系保存在缓存中,以备下次别的用户查询时,可以直接返回结果,加快网络访问。



Nginx配置多站点——超详细

🐇Q: 举个栗子,Loki在腾讯云买了一台云服务器,它制定了一个**公网ip地址**,我们就可以通过这个公网ip来访问这台主机,一台主机绑定一个IP地址,这样子就有可能出现以下问题

🎯A:对于这个主机,很多时候我们开启了一个站点,没有那么多人同时来访问,那么这台主机上的资源是不是就浪费了,而且由于技术进步,主机性能愈发优秀,这种情况下,那我们再一台主机上只跑一个站点,那是非常非常浪费的

解决方案

我们可以让多个站点对应一台主机,也就是多个域名对应一个ip来解决上述问题

Nginx 服务器可以通过配置server块的内容,通过不同serever块监听端口来判断用户究竟是访问哪个域名,再返回指向不同的站点的目录

🐓我们来实现这样一个简单的业务场景,你可以跟着Loki一起尝试一下

具体实现如下:

  1. 新增一个站点的server块配置,这是完整的nginx.conf文件,相对于最小配置只增加了一个Server块

    worker_processes 1;
    events {worker_connections 1024;
    }
    http {include mime.types;#当然了,Server块可以在其他地方写,在这里引入,会方便管理,Loki选择偷懒直接在下面写了default_type application/octet-stream;sendfile on;keepalive_timeout 65;server {listen 80;# 站点域名,Loki的云服务器ip没有进行解析,所以就是本机localhostserver_name localhost;location / {root html;index index.html index.htm;}error_page 500 502 503 504 /50x.html;location = /50x.html {root html;}}server {listen 88; # 监听端口# 站点域名,Loki的云服务器ip没有进行解析,所以就是本机localhostserver_name localhost; location / {#页面的路径,这个是系统资源的绝对路径,需要你自己写root /home/loki/blog; index index.html index.htm;}#错误页服务器错误重定向地址error_page 500 502 503 504 /50x.html; location = /50x.html {root html;} }
    }

  2. 在你server块中配置了资源路径/home/loki/www/blog,因此Loki新建了这个目录,存放了资源文件

    即:/home/loki/www/blog/index.html

    DOCTYPE html>
    <html lang&#61;"en">
    <head><meta charset&#61;"UTF-8"><meta http-equiv&#61;"X-UA-Compatible" content&#61;"IE&#61;edge"><meta name&#61;"viewport" content&#61;"width&#61;device-width, initial-scale&#61;1.0"><title>Nginx88端口title>
    head>
    <body><h1>88端口h1><h1>Nginx实现同一ip多站点配置h1>
    body>
    html>

  3. 重启Nginx服务


  • nginx -s reload
  • 如果注册了系统服务&#xff0c;可以使用systemctl reload nginx重启&#xff0c;使用systemctl status nginx查看是否重启成功

访问&#xff0c;运行结果截图

这里需要注意&#xff0c;如果端口访问不了&#xff0c;有可能是防火墙的原因

访问默认端口出现Nginx页面

image-20220427181348760

访问88端口出现自定义页面

image-20220427181332519

你可以通过这个在网上部署自己的静态博客&#xff0c;通过ip或域名访问&#xff0c;向下面这样

image-20220427182351962


六、Nginx基础命令

查看nginx是否启动

ps -ef|grep nginx

停止nginx服务

cd /usr/local/nginx/sbin #这个是你的Nginx安装目录
./nginx -s stop

查看 nginx 的版本号

cd /usr/local/nginx/sbin #这个是你的Nginx安装目录
./nginx -v

重新加载 nginx

./nginx -s reload


推荐阅读
  • 电商高并发解决方案详解
    本文以京东为例,详细探讨了电商中常见的高并发解决方案,包括多级缓存和Nginx限流技术,旨在帮助读者更好地理解和应用这些技术。 ... [详细]
  • 本文详细介绍了Java代码分层的基本概念和常见分层模式,特别是MVC模式。同时探讨了不同项目需求下的分层策略,帮助读者更好地理解和应用Java分层思想。 ... [详细]
  • 我的读书清单(持续更新)201705311.《一千零一夜》2006(四五年级)2.《中华上下五千年》2008(初一)3.《鲁滨孙漂流记》2008(初二)4.《钢铁是怎样炼成的》20 ... [详细]
  • 本文详细探讨了在Web开发中常见的UTF-8编码问题及其解决方案,包括HTML页面、PHP脚本、MySQL数据库以及JavaScript和Flash应用中的乱码问题。 ... [详细]
  • PHP面试题精选及答案解析
    本文精选了新浪PHP笔试题及最新的PHP面试题,并提供了详细的答案解析,帮助求职者更好地准备PHP相关的面试。 ... [详细]
  • 用阿里云的免费 SSL 证书让网站从 HTTP 换成 HTTPS
    HTTP协议是不加密传输数据的,也就是用户跟你的网站之间传递数据有可能在途中被截获,破解传递的真实内容,所以使用不加密的HTTP的网站是不 ... [详细]
  • 服务器部署中的安全策略实践与优化
    服务器部署中的安全策略实践与优化 ... [详细]
  • 在Java分层设计模式中,典型的三层架构(3-tier application)将业务应用细分为表现层(UI)、业务逻辑层(BLL)和数据访问层(DAL)。这种分层结构不仅有助于提高代码的可维护性和可扩展性,还能有效分离关注点,使各层职责更加明确。通过合理的设计和实现,三层架构能够显著提升系统的整体性能和稳定性。 ... [详细]
  • 提升 Kubernetes 集群管理效率的七大专业工具
    Kubernetes 在云原生环境中的应用日益广泛,然而集群管理的复杂性也随之增加。为了提高管理效率,本文推荐了七款专业工具,这些工具不仅能够简化日常操作,还能提升系统的稳定性和安全性。从自动化部署到监控和故障排查,这些工具覆盖了集群管理的各个方面,帮助管理员更好地应对挑战。 ... [详细]
  • H5技术实现经典游戏《贪吃蛇》
    本文将分享一个使用HTML5技术实现的经典小游戏——《贪吃蛇》。通过H5技术,我们将探讨如何构建这款游戏的两种主要玩法:积分闯关和无尽模式。 ... [详细]
  • 本文详细介绍了Oracle 11g中的创建表空间的方法,以及如何设置客户端和服务端的基本配置,包括用户管理、环境变量配置等。 ... [详细]
  • 本文介绍了SIP(Session Initiation Protocol,会话发起协议)的基本概念、功能、消息格式及其实现机制。SIP是一种在IP网络上用于建立、管理和终止多媒体通信会话的应用层协议。 ... [详细]
  • 本文详细介绍了如何使用Heartbeat构建一个高可用性的Apache集群,包括安装、配置和测试步骤。 ... [详细]
  • 本文介绍了两种有效的方法来解决DataSnap支持的Tcp长连接数受限的问题。方案一通过代理服务器实现负载均衡,方案二则利用多进程技术提升连接数。 ... [详细]
  • 2021年Java开发实战:当前时间戳转换方法详解与实用网址推荐
    在当前的就业市场中,金九银十过后,金三银四也即将到来。本文将分享一些实用的面试技巧和题目,特别是针对正在寻找新工作机会的Java开发者。作者在准备字节跳动的面试过程中积累了丰富的经验,并成功获得了Offer。文中详细介绍了如何将当前时间戳进行转换的方法,并推荐了一些实用的在线资源,帮助读者更好地应对技术面试。 ... [详细]
author-avatar
森tu罗宝殿
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有