Apache简介
#Apache HTTP Server(简称Apache)是Apache软件基金会的一个开放源码的网页服务器,Apache是世界使用排名第一的Web服务器软件。它可以运行在几乎所有广泛使用的计算机平台上,由于其跨平台和安全性被广泛使用,是最流行的Web服务器端软件之一。
//Apache的主程序名叫httpd。
//eg:在同一台服务器上启动多个相同apache进程。只要端口不一样就可以。
一、apache安装
[root@localhost ~]# systemctl stop firewalld
[root@localhost ~]# systemctl disable firewalld
[root@localhost ~]# setenforce 0
[root@localhost ~]# yum install -y httpd
[root@localhost ~]# systemctl start httpd
[root@localhost ~]# netstat -lntp | grep 80 #查看apache端口
tcp6 0 0 ::: 80 ::😗
LISTEN 2776/httpd
#端口80.可以改
#index.html:默认主页名称
#默认发布网站的目录:/var/www/html
#系统产生apache账户,家目录是:/var/www
二、apache目录介绍
#apache的工作目录(基准目录)
#conf 存储配置文件
#conf.d 存储配置子文件
#logs 存储日志
#modules 存储模块
#run 存储Pid文件,存放的pid号码。是主进程号
// 认识主配置文件:
#vim /etc/httpd/conf/httpd.conf
ServerRoot “/etc/httpd” #工作目录
Listen 80 #监听端口
Listen 192.168.2.8:80 指定监听的本地网卡 可以修改
User apache # 子进程的用户,有可能被人改称www账户
Group apache # 子进程的组
ServerAdmin root@localhost # 设置管理员邮件地址
DocumentRoot “/var/www/html” # 发布网站的默认目录,想改改这里。
IncludeOptional conf.d/.conf # 包含conf.d目录下的.conf文件
#设置DocumentRoot指定目录的属性
<Directory “/var/www/html”> # 网站容器开始标识
Options Indexes FollowSymLinks # 找不到主页时,以目录的方式呈现,并允许链接到网站根目录以外
AllowOverride None # 对目录设置特殊属性:none不使用.htaccess控制,all允许
Require all granted # granted表示运行所有访问,denied表示拒绝所有访问
容器结束
DirectoryIndex index.html # 定义主页文件,当访问到网站目录时如果有定义的主页文件,网站会自动访问
三、访问控制
1、准备测试页面:
[root@localhost ~]# echo test1 > /var/www/html/index.html #编写测试文件
2、访问控制测试:
#可以直接编辑apache主配置文件
[root@localhost ~]# vim /etc/httpd/conf/httpd.conf //默认所有主机访问
![打开主配置文件,按ESC键,冒号键,输入set nu就可以看见行数]
[root@localhost ~]# systemctl restart httpd #重启服务器
在网页输入自己主机IP地址即可查看搭建结果。
[root@localhost ~]# vim /etc/httpd/conf/httpd.conf #只拒绝一部分客户端访问
[root@localhost ~]# systemctl restart httpd #重启服务器
输入IP地址查看结果为禁止访问。
[root@test ~]# curl -I http://192.168.153.144 #用另外一台机器测试访问成功
HTTP/1.1 200 OK
Date: Thu, 06 Aug 2020 20:40:37 GMT
Server: Apache/2.4.6 (CentOS)
Last-Modified: Thu, 06 Aug 2020 20:12:02 GMT
ETag: “6-5ac3b1a02ac4f”
Accept-Ranges: bytes
Content-Length: 6
Content-Type: text/html; charset=UTF-8
//在Linux中curl是一个利用URL规则在命令行下工作的文件传输工具,它支持文件的上传和下载,是综合传输工具,习惯称url为下载工具。
-o:指定下载路径
-I:查看服务器的响应信息
[root@localhost ~]# vim /etc/httpd/conf/httpd.conf #拒绝所有人
[root@test ~]# systemctl restart httpd #重启服务器
在网页输入IP地址查看,结果为禁止访问
[root@test ~]# curl -I http://192.168.153.144
HTTP/1.1 403 Forbidden
Date: Thu, 06 Aug 2020 20:38:00 GMT
Server: Apache/2.4.6 (CentOS)
Content-Type: text/html; charset=iso-8859-1
#修改默认网站发布目录
[root@localhost ~]# vim /etc/httpd/conf/httpd.conf
119 DocumentRoot “/www” # 修改网站根目录为/www
131 <Directory “/www”> # 把这个也对应的修改为/www
[root@localhost ~]# mkdir /www ##创建定义的网站发布目录
[root@localhost ~]# echo “这是新修改的网站家目录/www” > /www/index.html #创建测试页面
[root@localhost ~]# systemctl restart httpd #重启服务
在网页输入IP地址进行访问
三、虚拟主机
#虚拟主机:多个网站在一台服务器上。web服务器都可以实现。
三种:基于域名 基于端口 基于Ip
1.基于域名
[root@localhost ~]# cd /etc/httpd/conf.d/
[root@localhost conf.d]# vim test.conf #创建配置文件
<VirtualHost :80> #指定虚拟主机端口,代表监听本机所有ip,也可以指定ip
DocumentRoot /soso #指定发布网站目录,自己定义
ServerName www.soso666.com #指定域名,可以自己定义
<Directory “/soso/”>
AllowOverride None #设置目录的特性,如地址重写
Require all granted #允许所有人访问
<VirtualHost *:80>
DocumentRoot /soho
ServerName test.soso666.com
<Directory “/soho/”>
AllowOverride None
Require all granted
[root@localhost ~]# mkdir /soso #创建发布目录
[root@localhost ~]# mkdir /soho
[root@localhost ~]# echo qianfen > /soso/index.html #创建测试页面
[root@localhost ~]# echo qfedu > /soho/index.html
[root@localhost ~]# systemctl restart httpd
#在wind电脑上面打开C:\Windows\System32\drivers\etc\hosts文件。可以用管理员身份打开
测试访问:在虚拟机网页端输入IP查看或者在命令行输入curl ip或者输入curl 域名查看结果。
2、 基于端口
[root@local host ~]# vim /etc/httpd/conf/httpd.conf —添加
[root@localhost ~]# vim /etc/httpd/conf.d/test.conf
<VirtualHost *:80>
DocumentRoot /soso
ServerName www.soso666.com
<Directory “/soso/”>
AllowOverride None
Require all granted
<VirtualHost *:81> #修改端口
DocumentRoot /soho
ServerName test.soso666.com
<Directory “/soho/”>
AllowOverride None
Require all granted
[root@localhost ~]# systemctl restart httpd
注意:解析并没有变
输入curl ip 或者输入curl 域名(www.soso666.com)可以查看www.soso666.com网站写入的内容。输入curl 域名(test.soso666.com)查看test.soso666.com写入的东西。
3.基于IP
[root@localhost ~]# ifconfig ens33:0 192.168.153.123 #添加一个临时ip
[root@localhost ~]# vim /etc/httpd/conf.d/test.conf
<VirtualHost 192.168.153.144:80> #指定ip
DocumentRoot /soso
ServerName www.soso666.com
<Directory “/soso/”>
AllowOverride None
Require all granted
<VirtualHost 192.168.153.123:80> #指定ip
DocumentRoot /soho
ServerName test.soso666.com
<Directory “/soho/”>
AllowOverride None
Require all granted
[root@localhost ~]# systemctl restart httpd
#取消添加的ip地址
#ifconfig ens33:0 192.168.153.123 down
//可以配置本地解析,也可以不配本地解析
版权归原作者 思君此何极 所有, 如有侵权,请联系我们删除。