Apache服务(基于IP地址,主机名,端口号)
安装Apache服务程序
需要注意apache服务程序的软件包名称叫做httpd,因此直接执行yum install apache则是错误的。
[root@liuxuanke-hbza ~]# yum install httpd*

使用Vim编辑器创建Yum仓库的配置文件:
[root@liuxuanke-hbza ~]# vim /etc/yum.repos.d/rhel7.repo
[rhel7]
name=rhel7
baseurl=file:///media/cdrom
enabled=1
gpgcheck=0
运行Apache服务程序并设置为开机启动
启动Apache服务程序:
[root@liuxuanke-hbza ~]# systemctl start httpd
设置为开机自启动:
[root@liuxuanke-hbza ~]# systemctl enable httpd
基于IP地址
一台服务器拥有多个IP地址,当用户访问不同IP地址时显示不同的网站页面。
1、使用nmtui命令为网卡添加多个IP地址(192.168.10.100/110/120):
重新启动网卡设备后使用ping命令检查是否配置正确(这项很重要,一定要测试好再进行下一步!)

2、分别创建网站数据目录
在/home/wwwroot目录下分别创建三个网站数据目录:
[root@liuxuanke-hbza ~]# mkdir -p /home/wwwroot/100
[root@liuxuanke-hbza ~]# mkdir -p /home/wwwroot/110
[root@liuxuanke-hbza ~]# mkdir -p /home/wwwroot/120
分别在这三个网站数据目录中写入主页文件,内容为该网站的IP地址:
[root@liuxuanke-hbza ~]# echo "IP:192.168.10.100" > /home/wwwroot/100/index.html
[root@liuxuanke-hbza ~]# echo "IP:192.168.10.110" > /home/wwwroot/110/index.html
[root@liuxuanke-hbza ~]# echo "IP:192.168.10.120" > /home/wwwroot/120/index.html
3、在配置文件(/etc/httpd/conf/httpd.conf)中描述基于主机名称的虚拟主机

4、修改网站数据目录的SELinux安全上下文

立即恢复SELinux安全上下文:
[root@liuxuanke-hbza ~]# restorecon -Rv /home/wwwroot
重启服务
[root@liuxuanke-hbza ~]# systemctl restart httpd
分别访问一下,验证结果



完成本次实验之后请还原虚拟机在进行以下实验
基于主机名
当服务器无法为每个网站都分配到独立IP地址时,可以试试让Apache服务程序自动识别来源主机名或域名然后跳转到指定的网站。
1、配置网卡IP地址与hosts文件
hosts文件作用是定义IP地址与主机名的映射关系,即强制将某个主机名地址解析到指定的IP地址

[root@liuxuanke-hbza ~]# vim /etc/hosts
//每行只能写一条,格式为IP地址+空格+主机名(域名)。
192.168.10.100 www.centos.com
192.168.10.100 bbs.centos.com
192.168.10.100 tech.centos.com

2、分别创建网站数据目录
[root@liuxuanke-hbza ~]# mkdir -p /home/wwwroot/www
[root@liuxuanke-hbza ~]# mkdir -p /home/wwwroot/bbs
[root@liuxuanke-hbza ~]# mkdir -p /home/wwwroot/tech
分别在网站目录中写入不同的首页文件:
[root@liuxuanke-hbza ~]# echo "www.centos.com" > /home/wwwroot/www/index.html
[root@liuxuanke-hbza ~]# echo "bbs.centos.com" > /home/wwwroot/bbs/index.html
[root@liuxuanke-hbza ~]# echo "tech.centos.com" > /home/wwwroot/tech/index.html

3、在配置文件中描述基于主机名称的虚拟主机
<VirtualHost 192.168.10.100>
DocumentRoot "/home/wwwroot/www"
ServerName "www.centos.com"
<Directory "/home/wwwroot/www">
AllowOverride None
Require all granted
</directory>
</VirtualHost>
<VirtualHost 192.168.10.100>
DocumentRoot "/home/wwwroot/bbs"
ServerName "bbs.centos.com"
<Directory "/home/wwwroot/bbs">
AllowOverride None
Require all granted
</Directory>
</VirtualHost>
<VirtualHost 192.168.10.100>
DocumentRoot "/home/wwwroot/tech"
ServerName "tech.centos.com"
<Directory "/home/wwwroot/tech">
AllowOverride None
Require all granted
</directory>
</VirtualHost>

重启服务
[root@liuxuanke-hbza ~]# systemctl restart httpd
设置为开机自启动:
[root@liuxuanke-hbza ~]# systemctl enable httpd
5、分别访问网站验证结果



请注意还原虚拟机快照再进行下一个实验,否则可能导致配置文件冲突而报错。
基于端口号
我们可以让服务器开启多个服务端口后,然后让用户能够通过访问服务器的指定端口来找到想要的网站。
1、配置服务器的IP地址

2、分别创建网站数据目录
分别创建端口为6111,6222的网站数据目录:
[root@liuxuanke-hbza ~]# mkdir -p /home/wwwroot/6111
[root@liuxuanke-hbza ~]# mkdir -p /home/wwwroot/6222
分别在网站数据目录中写入不同内容的主页文件:
[root@liuxuanke-hbza ~]# echo "port:6111" > /home/wwwroot/6111/index.html
[root@liuxuanke-hbza ~]# echo "port:6222" > /home/wwwroot/6222/index.html

3、在配置文件中描述基于端口号的虚拟主机
编辑主配置文件(/etc/httpd/conf/httpd.conf),找到约在42行的Listen 80,并在下面追加:
Listen 6111
Listen 6222
然后在主配置文件的末尾按下面格式定义虚拟主机信息:
<VirtualHost 192.168.10.10:6111>
DocumentRoot ''/home/wwwroot/6111"
ServerName www.linuxprobe.com
<Directory "/home/wwwroot/6111''>
AllowOverride None
Require all granted
</Directory>
</VirtualHost>
<VirtualHost 192.168.10.10:6222>
DocumentRoot "/home/wwwroot/6222"
ServerName bbs.linuxprobe.com
<Directory "/home/wwwroot/6222">
AllowOverride None
Require all granted
</Directory>
</VirtualHost>
修改完后,记得重启服务

出现了错误这是因为SELinux服务检测到6111与6222端口原本并不属于Apache服务端口,但现在却被以Apache的名义监听了
4、修改网站数据目录的SELinux安全上下文并允许端口监听

让新的SElinux安全上下文立即生效:
[root@liuxuanke-hbza ~]# restorecon -Rv /home/wwwroot/
使用semanage命令搜索在SELinux系统中有关http服务的端口号:
[root@liuxuanke-hbza ~]# semanage port -l| grep http

默认的端口号中没有6111 、6222,所以需要添加
[root@liuxuanke-hbza ~]# semanage port -a -t http_port_t -p tcp 6111
[root@liuxuanke-hbza ~]# semanage port -a -t http_port_t -p tcp 6222
再来看下SELinux的端口规则(已经添加成功了):

再尝试启动服务程序就没有问题了 systemctl restart httpd
5、分别访问网站查看验证结果


Apache服务(基于IP地址,主机名,端口号)的更多相关文章
- Apache(基于IP地址)
1.Apache的安装 (1)先用命令“cat /etc/passwd|grep apache”,查看有有没有Apache ①如果有Apache,我们就不用再安装 ②如果没有,我们就安装一下 (2)使 ...
- Linux下设置ip和主机名进行绑定
1:输入命令gedit /etc/hosts 这样你就打开了一个文本,然后在文本的末尾进行加入例如以下: ip地址 主机名 192.168.0.125 h ...
- Apache的虚拟主机功能(基于IP地址、基于虚拟主机、基于端口)
1. 安装Apache服务程序(系统用户,1-199之间) 第一步:在虚拟机软件里选中光盘镜像: 第二步:将光盘设备挂载到/media/cdrom目录 输入:mkdir -p /media/cdrom ...
- 使用Apache服务部署网站(基于IP,域名,端口)
本篇主要学习Apache网站服务程序的基本部署,基于IP地址.主机名(域名).端口号的虚拟主机功能. 1.基于IP地址 首先我们需要在虚拟机中线安装Apache服务程序,Apache服务程序的软件包名 ...
- nginx篇最初级用法之三种虚拟主机基于域名\基于端口\基于IP地址端口的虚拟主机
在nginx中虚拟主机的类型与apache一样也有三种 1.基于域名的虚拟主机 2.基于端口的虚拟主机 3.基于IP地址端口的虚拟主机 在nginx配置文件中每一个server为一个虚拟主机如果需要多 ...
- 根据IP查主机名和MAC地址
根据IP查主机名: nbtstat -a XXX.XXX.XXX.XXX根据IP查MAC地址: arp -a XXX.XXX.XXX.XXXXXX.XXX.XXX.XXX指代要查的主机的IP
- iptables只允许指定ip地址访问指定端口
首先,清除所有预设置 iptables -F#清除预设表filter中的所有规则链的规则 iptables -X#清除预设表filter中使用者自定链中的规则 其次,设置只允许指定ip地址访问指定端口 ...
- linux下通过iptables只允许指定ip地址访问指定端口的设置方法
这篇文章主要介绍了linux下通过iptables只允许指定ip地址访问指定端口的设置方法,需要的朋友可以参考下. 首先,清除所有预设置 iptables -F#清除预设表filter中的所有规则链的 ...
- 扫描局域网内的ip和主机名
1. 目的 今天发现我配置的一台电脑ip被人占用了,所以准备写个程序扫描一下局域网内所有正在使用的ip和主机名 2. 实现--直接上代码 import time import threading im ...
随机推荐
- 个人作业 项目alpha版本测试
课程:https://edu.cnblogs.com/campus/xnsy/SoftwareEngineeringClass2 作业要求:https://edu.cnblogs.com/campus ...
- Linux之目录配置
Linux目录配置标准:FHS 主要目的,希望让用户可以了解到已安装软件通常放置于哪个目录下. FHS定义了三层主目录:/./usr./var 1. /(root,根目录) (1)根目录与开机.还原. ...
- 2019 计蒜之道 复赛 D. “星云系统”(单调栈)
VIPKID 是在线少儿英语教育平台,网络稳定是在线教育课程质量的红线,VIPKID 为此推出了全球最稳定的教育网络系统 -- "星云系统".星云系统目前建立了覆盖全球 3535 ...
- Codeforces 946 课程表背包DP 数位DFS构造
A B 给你A,B 两个数 1.a=0 OR b=0 break 2.a>=2b a=a-2b 3.b>=2a b=b-2a 如果只是单纯模拟肯定会超时 ...
- php内置函数分析array_count_values()
PHP_FUNCTION(array_count_values) { zval *input, /* Input array */ *entry, /* An entry in the input a ...
- 浅谈C++ allocator内存管理(对比new的局限性)(转)
STL中,对内存管理的alloc的设计,迫使我去学习了allocator类.这里对allocator内存管理做了点笔记留给自己后续查阅.allocator类声明.定义于头文件<memory> ...
- GitLab5
GitLab5发布快一个月了,决定试用下,5.0最大的特性就是用GitLab-Shell取代了Gitolite,这大大降低了安装难度,不多本人在安装过程中还是越到了一些问题,所以记录下来供要安装Git ...
- 【leetcode】1171. Remove Zero Sum Consecutive Nodes from Linked List
题目如下: Given the head of a linked list, we repeatedly delete consecutive sequences of nodes that sum ...
- vim 复制
要复制到别的地方,用 "+y 来复制,注意是三个字符.gg"+yG 1.复制 1)单行复制 在命令模式下,将光标移动到将要复制的行处,按“yy”进行复制: 2)多行复制 在命令模式 ...
- 【后台管理系统】—— Ant Design Pro页面相关(一)
一.List列表形式 import React, { PureComponent } from 'react'; import { findDOMNode } from 'react-dom'; im ...