我使用了两台ubuntu的虚拟机来完成今天这测试
我事先申明一下这些服务器主机 首先A代表的我的nginx的服务器 用来做反向代理 另一台服务器使用apache搭建的服务 我利用nginx服务器将请求转发到另一台服务器 本机先给A服务器做一个虚拟域名 在/etc/hosts 里面添加 域名 ip 然后用本机去ping你做的虚拟域名 保证这个能互相连通 再去进行其他操作 如果网络都不能互通这个怎么去配置??
/img/post-linux-pd/lamp.png”
配置nginx服务器
- sudo apt-get install nginx 安装一个nginx服务器 不使用default
去nginx配置那 sites-available cp default文件改名为你自己想要配置的名称 将default里面监听的端口注释掉 到sites-enabled做一下软连接 将该文件链接进来 nginx -s reload 重启一下服务器 之后去使用本级去访问一下配置的域名 访问成功即可
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
ln -s 目标文件 当前文件地址
// 简单介绍一下软链接 和 硬链接
ln是linux中又一个非常重要命令,它的功能是为某一个文件在另外一个位置建立一个同步的链接.当我们需要在不同的目录,用到相同的文件时,我们不需要在每一个需要的目录下都放一个必须相同的文件,我们只要在某个固定的目录,放上该文件,然后在 其它的目录下用ln命令链接(link)它就可以,不必重复的占用磁盘空间。
1.命令格式:
ln [参数][源文件或目录][目标文件或目录]
2.命令功能:
Linux文件系统中,有所谓的链接(link),我们可以将其视为档案的别名,而链接又可分为两种 : 硬链接(hard link)与软链接(symbolic link),硬链接的意思是一个档案可以有多个名称,而软链接的方式则是产生一个特殊的档案,该档案的内容是指向另一个档案的位置。硬链接是存在同一个文件系统中,而软链接却可以跨越不同的文件系统。
软链接:
1.软链接,以路径的形式存在。类似于Windows操作系统中的快捷方式
2.软链接可以 跨文件系统 ,硬链接不可以
3.软链接可以对一个不存在的文件名进行链接
4.软链接可以对目录进行链接
硬链接:
1.硬链接,以文件副本的形式存在。但不占用实际空间。
2.不允许给目录创建硬链接
3.硬链接只有在同一个文件系统中才能创建
这里有两点要注意:
第一,ln命令会保持每一处链接文件的同步性,也就是说,不论你改动了哪一处,其它的文件都会发生相同的变化;
第二,ln的链接又分软链接和硬链接两种,软链接就是ln –s 源文件 目标文件,它只会在你选定的位置上生成一个文件的镜像,不会占用磁盘空间,硬链接 ln 源文件 目标文件,没有参数-s, 它会在你选定的位置上生成一个和源文件大小相同的文件,无论是软链接还是硬链接,文件都保持同步变化。
ln指令用在链接文件或目录,如同时指定两个以上的文件或目录,且最后的目的地是一个已经存在的目录,则会把前面指定的所有文件或目录复制到该目录中。若同时指定多个文件或目录,且最后的目的地并非是一个已存在的目录,则会出现错误信息。
3.命令参数:
必要参数:
-b 删除,覆盖以前建立的链接
-d 允许超级用户制作目录的硬链接
-f 强制执行
-i 交互模式,文件存在则提示用户是否覆盖
-n 把符号链接视为一般目录
-s 软链接(符号链接)
-v 显示详细的处理过程
配置apache服务器
使用ubuntu一键安装lamp环境
1
2
3
4
sudo apt-get install tasksel 先安装这个工具 之后再去安装lamp
sudo tasksel install lamp-server 脑残式安装
sudo tasksel remove lamp-server 这是卸载 不想要就卸载掉了
Apache2 Ubuntu Default Page 页面说明你的环境搭建成功了
每台服务器都设置一个域名访问 该域名就是你在本机 的虚拟域名 都用域名去访问一下 能看到自己设定的内容就算成功
最后去配置一下nginx服务配置文件就可以了 访问出现你的自定义内容 成功
1
2
3
4
5
6
7
8
9
10
11
12
13
往nginx.conf 里面的location 里面添加
proxy_set_header X-Real-IP $remote_addr; 设置使用用户真实ip转发到apache 不设置的话apache日志存的访问都是nginx的ip 都是使用nginx转发过去的
proxy_set_header Host $http_host; 不设置个域名转发的话 转发到的都是你服务器的ip地址 如果你另一台服务器上配置了虚拟主机就需要了
proxy_pass http://192.168.31.211:80; 需要转发的地址
client_max_body_size 35m;
proxy_http_version 1.1;
// 如果要使用长连接 需要配置这个 我们这里就不配置了
# proxy_set header Upgrade $http upgrade;
# proxy_set header Connection "upgrade";