Apache的部署三之构建虚拟主机(基于IP、基于域名、基于端口号) 、访问控制 、支持的多种语言脚本编写

本文主要是介绍Apache的部署三之构建虚拟主机(基于IP、基于域名、基于端口号) 、访问控制 、支持的多种语言脚本编写,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1. 构建虚拟主机(全新实验环境)

(1)构建的目的

  • 如果每台Linux服务器上都为一个网站所用的话,那对于那种访问量少的网站就要承担较高的服务器租赁费而入不敷出了。所以apache就实现了一台服务器上可以建立多个虚拟主机的功能模块,从而达到多个网站分布在一个服务器上,节省硬件资源的目的。访问不同的网站(域名)时,目的地址都为同一台主机,但在客户端是察觉不到的,这就大大节约了小网站的发布成本。

  • 实质:编写多个发布目录,不同的(IP、PORT、域名)指向不同的发布内容。

(2)搭建方法

1、基于域名

#####建立发布目录
[root@server1 www]# mkdir -p virtual/westos.org/{linux,bbs,lee}    //没有新建目录是为了保持安全上下文一致,不用再去更改目录及文件的安全上下文
##.建立并编写发布文件:必须是默认发布文件index.html,否则还需要添加到主配置文件中指定发布文件
[root@server1 www]# echo "linux.westos.org" >> virtual/westos.org/linux/index.html
[root@server1 www]# echo "bbs.westos.org" >> virtual/westos.org/bbs/index.html
[root@server1 www]# echo "lee.westos.org" >> virtual/westos.org/lee/index.html
####编写子配置文件
[root@apache-server conf.d]# vim vhost.conf   //可以是任意名字,只要以.conf结尾,且放在/etc/httpd/conf.d/子目录下。

在这里插入图片描述
头部为<VirtualHost _default_:80> 下划线被遮住了。
还有一种编写方式为:<VirtualHost 172.25.254.209>:此种强制访问该目录下内容,覆盖一切。当有两个一样的时,以第一个为默认。

<VirtualHost_default_:80>DocumentRoot /var/www/htmlCustomLog logs/default.log combined
</VirtualHost>
以上是虚拟主机的基本信息
<VirtualHost *:80>ServerName news.westos.comDocumentRoot /var/www/vhost/newsCustomLog logs/news.log combined
</VirtualHost>
<Directory "/var/www/vhost/news">Require all granted
</Directory>
以上是news这个虚拟站点的基本信息和授权信息
<VirtualHost *:80>ServerName music.westos.comDocumentRoot /var/www/vhost/musicCustomLog logs/music.log combined
</VirtualHost>
<Directory "/var/www/vhost/music">Require all granted
</Directory>
以上是music这个虚拟站点的基本信息和授权信息
systemctl restart httpd重启才会生效
###在用浏览器访问的主机上做本地解析
[root@foundation34 Desktop]# vim /etc/hosts
###
172.25.254.134 www.westos.com news.westos.com music.westos.com
###重启服务
[root@apache-server conf.d]# systemctl restart httpd.service 

网页测试:
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
2、基于端口

我们可以让服务器开启多个服务端口后,然后让用户能够通过访问服务器的指定端口来找到想要的网站。

第一步:将端口号添加到selinux及firewalld策略中:

[root@server1 conf.d]# systemctl start firewalld
[root@server1 conf.d]# firewall-cmd --add-port=6666/tcp --permanent 
success
[root@server1 conf.d]# firewall-cmd --add-port=7777/tcp --permanent 
success
[root@server1 conf.d]# firewall-cmd --reload
success
[root@server1 conf.d]# semanage port -a -t http_port_t -p tcp 6666
[root@server1 conf.d]# semanage port -a -t http_port_t -p tcp 7777

第二步:创建访问目录,写入显示页内容:

[root@server1 virtual]# mkdir 6666
[root@server1 virtual]# mkdir 7777
[root@server1 virtual]# echo "the port is 6666" > 6666/index.html
[root@server1 virtual]# echo "the port is 7777" > 7777/index.html

第三步:更改配置文件的监听端口:

[root@server1 conf.d]# vim /etc/httpd/conf/httpd.conf 

在这里插入图片描述
第四步:写入子配置文件,重启服务
在这里插入图片描述

[root@server1 conf.d]# systemctl restart httpd

在这里插入图片描述

第五步:测试网页
在这里插入图片描述
在这里插入图片描述
3、基于IP
由于现在基于IP 的配置需求较少,需要请点击这里
在这里插入图片描述

2. apache的访问控制

(1).基于ip(主机)的访问控制

(1)设定白名单:
[root@apache-server conf.d]# pwd
/etc/httpd/conf.d
[root@apache-server conf.d]# vim a_default.conf 

在这里插入图片描述
在白名单34主机上测试:
在这里插入图片描述
在134主机上测试:
在这里插入图片描述

(2)设定黑名单:
[root@apache-server conf.d]# vim a_default.conf

在这里插入图片描述

[root@apache-server conf.d]# systemctl restart httpd

在34主机上测试:
在这里插入图片描述

其他主机234上测试:

在这里插入图片描述
(2)基于用户的访问控制

 ##1.创建用户并设定密码;c表示create;将生成的用户和密码放入.http_userlist文件中
[root@server1 conf.d]# htpasswd -cm .http_userlist admin
##此时便会生成.http_userlist文件
[root@server1 conf.d]# htpasswd -m .http_userlist lee   //第二次建立用户的时候,就不用-c创建文件这个参数了。否则会直接把原来文件的用户覆盖掉,重新建立。

在这里插入图片描述

##.指定用户认证信息
[root@apache-server conf.d]# vim /etc/httpd/conf/httpd.conf

在这里插入图片描述

##4.重启服务[root@apache-server conf.d]# systemctl restart httpd

网页测试:
在这里插入图片描述
在这里插入图片描述

3. apache支持的语言

  • apache的默认语言是html,但它支持html、php、jsp、perl等等
  • apache对发布目录下的文件不具有执行解释功能,当需要编译需要下载插件。
    (1)php语言
##1.用php语言编写发布文件
[root@apache-server html]# vim index.php

在这里插入图片描述

##2.安装php
[root@apache-server html]# yum install -y php  //下载解释插件
##3.重启服务
[root@apache-server conf.d]# systemctl restart httpd

在这里插入图片描述

(2)自定义cgi接口语言

第一种:

/var/www/cgi-bin目录下编写发布文件(脚本)
[root@apache-server conf.d]# cd /var/www/
[root@apache-server www]# ls
cgi-bin  html  westos.com
[root@apache-server www]# cd cgi-bin/

查看apache帮助手册:

在这里插入图片描述
在这里插入图片描述

1.用cgi语言编写发布文件;可在apache帮助手册查到语法格式
[root@apache-server cgi-bin]# vim index.cgi

在这里插入图片描述

 ##2.给脚本一个可执行权限
[root@apache-server cgi-bin]# chmod +x index.cgi 
##3.执行脚本
[root@apache-server cgi-bin]# ./index.cgi 

在这里插入图片描述

网页测试:

在这里插入图片描述
第二种:

/var/www/html/cgi目录中编写发布文件(脚本)
[root@apache-server cgi-bin]# cd /var/www/html
##1.创建目录
[root@apache-server html]# mkdir cgi 
[root@apache-server html]# ls
cgi  index.html  index.php  westos.html
[root@apache-server html]# cd cgi/
[root@apache-server cgi]# pwd
/var/www/html/cgi
##2.拷贝文件
[root@apache-server cgi]# cp /var/www/cgi-bin/index.cgi .
[root@apache-server cgi]# ll
total 4
-rwxr-xr-x. 1 root root 67 Dec  3 23:25 index.cgi

在这里插入图片描述
查看apache帮助手册:
在这里插入图片描述

##3.编写子配置文件
[root@apache-server conf.d]# vim /etc/httpd/conf/httpd.conf 

在这里插入图片描述

##4.重启服务
[root@apache-server conf.d]# systemctl restart httpd
##查看安全上下文
[root@apache-server cgi]# ls -Zd /var/www/html/cgi/
##5.修改安全上下文
[root@apache-server cgi]# semanage fcontext -a -t httpd_sys_script_exec_t '/var/www/html/cgi(/.*)?'

在这里插入图片描述

##6.刷新
[root@apache-server cgi]# restorecon -RvvF /var/www/html/cgi/

网页测试:
在这里插入图片描述(3)wsgi 接口语言
直接在/var/www/cgi-bin/目录下写编写发布文件

##.下载脚本
[root@apache-server cgi-bin]# ls
webapp.wsgi  westos
##查看脚本;此脚本是用python写的
[root@apache-server cgi-bin]# vim webapp.wsgi

在这里插入图片描述

##3.给脚本一个可执行权限
[root@apache-server cgi-bin]# chmod +x webapp.wsgi
[root@apache-server cgi-bin]# yum search wsgi

在这里插入图片描述

##4.安装wsgi插件
[root@apache-server cgi-bin]# yum install -y mod_wsgi.x86_64 
##5.编写子配置文件
[root@apache-server conf.d]# vim webapp.conf

在这里插入图片描述

##6.重启apache[root@apache-server conf.d]# systemctl restart httpd##7.本地解析
[root@foundation34 ~]# vim /etc/hosts

在这里插入图片描述
网页测试:
在这里插入图片描述

这篇关于Apache的部署三之构建虚拟主机(基于IP、基于域名、基于端口号) 、访问控制 、支持的多种语言脚本编写的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/632841

相关文章

Debezium 与 Apache Kafka 的集成方式步骤详解

《Debezium与ApacheKafka的集成方式步骤详解》本文详细介绍了如何将Debezium与ApacheKafka集成,包括集成概述、步骤、注意事项等,通过KafkaConnect,D... 目录一、集成概述二、集成步骤1. 准备 Kafka 环境2. 配置 Kafka Connect3. 安装 D

ElasticSearch+Kibana通过Docker部署到Linux服务器中操作方法

《ElasticSearch+Kibana通过Docker部署到Linux服务器中操作方法》本文介绍了Elasticsearch的基本概念,包括文档和字段、索引和映射,还详细描述了如何通过Docker... 目录1、ElasticSearch概念2、ElasticSearch、Kibana和IK分词器部署

部署Vue项目到服务器后404错误的原因及解决方案

《部署Vue项目到服务器后404错误的原因及解决方案》文章介绍了Vue项目部署步骤以及404错误的解决方案,部署步骤包括构建项目、上传文件、配置Web服务器、重启Nginx和访问域名,404错误通常是... 目录一、vue项目部署步骤二、404错误原因及解决方案错误场景原因分析解决方案一、Vue项目部署步骤

Linux流媒体服务器部署流程

《Linux流媒体服务器部署流程》文章详细介绍了流媒体服务器的部署步骤,包括更新系统、安装依赖组件、编译安装Nginx和RTMP模块、配置Nginx和FFmpeg,以及测试流媒体服务器的搭建... 目录流媒体服务器部署部署安装1.更新系统2.安装依赖组件3.解压4.编译安装(添加RTMP和openssl模块

定价129元!支持双频 Wi-Fi 5的华为AX1路由器发布

《定价129元!支持双频Wi-Fi5的华为AX1路由器发布》华为上周推出了其最新的入门级Wi-Fi5路由器——华为路由AX1,建议零售价129元,这款路由器配置如何?详细请看下文介... 华为 Wi-Fi 5 路由 AX1 已正式开售,新品支持双频 1200 兆、配有四个千兆网口、提供可视化智能诊断功能,建

0基础租个硬件玩deepseek,蓝耘元生代智算云|本地部署DeepSeek R1模型的操作流程

《0基础租个硬件玩deepseek,蓝耘元生代智算云|本地部署DeepSeekR1模型的操作流程》DeepSeekR1模型凭借其强大的自然语言处理能力,在未来具有广阔的应用前景,有望在多个领域发... 目录0基础租个硬件玩deepseek,蓝耘元生代智算云|本地部署DeepSeek R1模型,3步搞定一个应

Ubuntu固定虚拟机ip地址的方法教程

《Ubuntu固定虚拟机ip地址的方法教程》本文详细介绍了如何在Ubuntu虚拟机中固定IP地址,包括检查和编辑`/etc/apt/sources.list`文件、更新网络配置文件以及使用Networ... 1、由于虚拟机网络是桥接,所以ip地址会不停地变化,接下来我们就讲述ip如何固定 2、如果apt安

redis群集简单部署过程

《redis群集简单部署过程》文章介绍了Redis,一个高性能的键值存储系统,其支持多种数据结构和命令,它还讨论了Redis的服务器端架构、数据存储和获取、协议和命令、高可用性方案、缓存机制以及监控和... 目录Redis介绍1. 基本概念2. 服务器端3. 存储和获取数据4. 协议和命令5. 高可用性6.

Deepseek R1模型本地化部署+API接口调用详细教程(释放AI生产力)

《DeepseekR1模型本地化部署+API接口调用详细教程(释放AI生产力)》本文介绍了本地部署DeepSeekR1模型和通过API调用将其集成到VSCode中的过程,作者详细步骤展示了如何下载和... 目录前言一、deepseek R1模型与chatGPT o1系列模型对比二、本地部署步骤1.安装oll

nginx部署https网站的实现步骤(亲测)

《nginx部署https网站的实现步骤(亲测)》本文详细介绍了使用Nginx在保持与http服务兼容的情况下部署HTTPS,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值... 目录步骤 1:安装 Nginx步骤 2:获取 SSL 证书步骤 3:手动配置 Nginx步骤 4:测