在Ubuntu中使用Apache2部署项目

1. 安装Apache2

bash 复制代码
sudo apt update
sudo apt install apache2 -y

安装完成后,Apache会自动启动,通过浏览器访问 http://服务器IP 应看到默认的Apache欢迎页。

2. 配置防火墙(UFW)

bash 复制代码
sudo ufw allow 'Apache'  # 允许Apache通过防火墙
sudo ufw status  # 检查状态

3. 部署项目文件

  • 自定义目录:/var/www/

若需使用其他目录(如/var/www/myproject),需确保Apache有权限访问:

bash 复制代码
#myproject替换成你的项目名字
sudo mkdir -p /var/www/myproject
sudo chown -R $USER:$USER /var/www/myproject  # 赋予当前用户权限
sudo chmod -R 755 /var/www/myproject  # 设置目录权限
  • 自定义html页面
bash 复制代码
echo '<!DOCTYPE html>
<html>
<head>
    <title>我的项目</title>
</head>
<body>
    <h1>Hello World!</h1>
</body>
</html>' | sudo tee /var/www/myproject/index.html > /dev/null

4. 配置虚拟主机

为每个项目创建独立的配置文件,避免冲突:

bash 复制代码
sudo cp /etc/apache2/sites-available/000-default.conf 
		/etc/apache2/sites-available/myproject.conf

编辑配置文件:

bash 复制代码
sudo nano /etc/apache2/sites-available/myproject.conf

修改以下内容(示例):

bash 复制代码
<VirtualHost *:80>
    ServerAdmin admin@example.com
    ServerName myproject.com  # 或服务器IP
    DocumentRoot /var/www/myproject
    ErrorLog ${APACHE_LOG_DIR}/error.log
    CustomLog ${APACHE_LOG_DIR}/access.log combined

    <Directory /var/www/myproject>
        Options Indexes FollowSymLinks
        AllowOverride All  # 允许.htaccess覆盖配置
        Require all granted
    </Directory>
</VirtualHost>

启用配置并重启Apache:

bash 复制代码
sudo a2ensite myproject.conf
sudo a2dissite 000-default.conf  # 可选:禁用默认配置
sudo systemctl restart apache2   # 重启Apache2

5. 测试与调试

  • 检查语法错误:
bash 复制代码
sudo apache2ctl configtest

以上就可以正常使用Http进行访问了,如果要设置成Https看后续操作,不过我这个Https只是测试项目使用,因为我没有域名,所以没办法申请Let's Encrypt的受信任的证书。

设置Https访问

  1. 安装必要软件
bash 复制代码
sudo apt update
sudo apt install apache2 openssl
  1. 生成自签名SSL证书
bash 复制代码
sudo openssl req -x509 -nodes -days 365 -newkey rsa:2048 \
  -keyout /etc/ssl/private/apache-selfsigned.key \
  -out /etc/ssl/certs/apache-selfsigned.crt \
  -subj "/C=US/ST=State/L=City/O=Organization/CN=localhost"

说明:
CN=localhost:本地测试时使用localhost作为通用名。
证书有效期为365天,到期后需重新生成。

  1. 启用SSL模块
bash 复制代码
sudo a2enmod ssl
sudo systemctl restart apache2
  1. 配置SSL虚拟主机

手动创建ssl配置文件:

bash 复制代码
sudo nano /etc/apache2/sites-available/localhost-ssl.conf
  • 内容:
bash 复制代码
<VirtualHost *:443>
    ServerName localhost
    DocumentRoot /var/www/html

    SSLEngine on
    SSLCertificateFile /etc/ssl/certs/apache-selfsigned.crt
    SSLCertificateKeyFile /etc/ssl/private/apache-selfsigned.key
</VirtualHost>
  1. 启用SSL虚拟主机
bash 复制代码
sudo a2ensite localhost-ssl.conf
sudo systemctl reload apache2
  1. 配置HTTP到HTTPS的重定向
    修改默认虚拟主机配置
bash 复制代码
sudo nano /etc/apache2/sites-available/000-default.conf
  • 添加以下内容:
bash 复制代码
<VirtualHost *:80>
    ServerName localhost
    Redirect permanent / https://localhost/
</VirtualHost>

启用重写模块:

bash 复制代码
sudo a2enmod rewrite
sudo systemctl reload apache2

总结

  • 自签名证书:仅适用于本地测试,生产环境需使用受信任的证书(如Let's Encrypt)。
  • 重定向:通过修改Apache配置或.htaccess实现HTTP到HTTPS的自动跳转。
  • 信任证书:浏览器会提示证书不安全,本地测试时可忽略或手动信任。
相关推荐
阿巴~阿巴~21 分钟前
Linux 信号的保存机制
linux·服务器·信号·信号集·信号保存
柱子子子子1 小时前
【邪修】linux (ubuntu/fedora/arch/debian) wifi hard blocked解决方法-AX210
linux·网络·ubuntu·debian
大龄Python青年1 小时前
Linux发行版Ubuntu24.04安装教程
linux·ubuntu·1024程序员节
强里秋千墙外道2 小时前
【Linux】ssh升级到最新版本-以ubuntu为例
linux·运维·ssh
先做个垃圾出来………2 小时前
Docker容器部署方法
运维·docker·容器
minhuan2 小时前
构建AI智能体:七十五、用扣子平台创建工作流:从自动化到智能化的进阶之路
运维·自动化·工作流构建·意图识别工作流
老实巴交的麻匪2 小时前
(八)学习、实践、理解 CI/CD 与 DevOps:持续集成 CI,从源代码到容器镜像
运维·云原生·自动化运维
9ilk3 小时前
【仿RabbitMQ的发布订阅式消息队列】--- 介绍
linux·笔记·分布式·后端·rabbitmq
馨谙3 小时前
OpenSSH 安全配置核心概念解析
linux·服务器·网络
半桔3 小时前
【IO多路转接】IO 多路复用之 select:从接口解析到服务器实战
linux·服务器·c++·github·php