在CentOS上配置LNMP(Linux, Nginx, MySQL, PHP)以实现数据加密传输,通常涉及以下几个步骤:
安装Nginx: 如果你还没有安装Nginx,可以使用以下命令进行安装:
sudo yum install epel-release
sudo yum install nginx
配置SSL证书: 为了实现HTTPS加密传输,你需要一个SSL证书。你可以从Let’s Encrypt免费获取一个证书,或者购买一个商业证书。
使用Certbot(Let’s Encrypt客户端)安装和配置SSL证书:
sudo yum install certbot python2-certbot-nginx
sudo certbot --nginx -d yourdomain.com -d www.yourdomain.com
Certbot会自动配置Nginx以使用SSL证书。
配置Nginx:
编辑Nginx配置文件(通常位于/etc/nginx/nginx.conf或/etc/nginx/conf.d/default.conf),确保以下配置存在并正确:
server {
listen 443 ssl;
server_name yourdomain.com www.yourdomain.com;
ssl_certificate /etc/letsencrypt/live/yourdomain.com/fullchain.pem;
ssl_certificate_key /etc/letsencrypt/live/yourdomain.com/privkey.pem;
include /etc/letsencrypt/options-ssl-nginx.conf;
ssl_dhparam /etc/letsencrypt/ssl-dhparams.pem;
location / {
root /var/www/html;
index index.php index.html index.htm;
}
location ~ \.php$ {
fastcgi_pass unix:/var/run/php-fpm/php-fpm.sock;
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
include fastcgi_params;
}
}
server {
listen 80;
server_name yourdomain.com www.yourdomain.com;
location / {
return 301 https://$host$request_uri;
}
}
配置MySQL: MySQL本身不直接提供数据传输加密,但你可以通过以下方式增强安全性:
编辑MySQL配置文件(通常位于/etc/my.cnf或/etc/mysql/my.cnf),添加以下配置:
[mysqld]
ssl-ca=/etc/mysql/ssl/ca.pem
ssl-cert=/etc/mysql/ssl/server-cert.pem
ssl-key=/etc/mysql/ssl/server-key.pem
[client]
ssl-ca=/etc/mysql/ssl/ca.pem
ssl-cert=/etc/mysql/ssl/client-cert.pem
ssl-key=/etc/mysql/ssl/client-key.pem
重启MySQL服务以应用更改:
sudo systemctl restart mysqld
配置PHP: 确保PHP代码中使用的数据库连接是加密的。例如,使用PDO连接MySQL时,可以这样配置:
$dsn = 'mysql:host=localhost;dbname=your_database;charset=utf8mb4';
$options = [
PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION,
PDO::ATTR_EMULATE_PREPARES => false,
PDO::MYSQL_ATTR_SSL_CA => '/etc/mysql/ssl/ca.pem',
PDO::MYSQL_ATTR_SSL_CERT => '/etc/mysql/ssl/client-cert.pem',
PDO::MYSQL_ATTR_SSL_KEY => '/etc/mysql/ssl/client-key.pem',
];
try {
$pdo = new PDO($dsn, 'your_username', 'your_password', $options);
} catch (PDOException $e) {
die('Connection failed: ' . $e->getMessage());
}
通过以上步骤,你可以在CentOS上配置LNMP以实现数据加密传输。确保定期更新你的SSL证书,并保持系统和软件的最新状态以维护安全性。