我们继续扩大我们的市场。 我们最近讨论了如何
我们讲述为什么选择它以及图像是如何创建的。
Drupal的 是一个方便而强大的平台,可用于创建任何类型的网站:从微型网站和博客到大型社交项目,它也用作 Web 应用程序的基础,用 PHP 编写并使用关系数据库作为数据存储。
Drupal 9 包含版本 8.9 中引入的所有功能。 版本 9 和版本 8 之间的主要区别在于,该平台将在 2021 年 9 月之后继续接收更新和安全修复。 同样在版本 8 中,升级过程也得到了简化,使得从版本 XNUMX 的升级过程变得更加容易。
服务器要求
要使用 Drupal,建议使用 2 GB RAM 和 2 个 CPU 内核。
主 Drupal 文件约为 100 MB,此外您还需要空间来存储图像、数据库、主题、附加组件和备份,这取决于您站点的大小。
Drupal 9 需要 PHP 7.4 或更高版本,但有最低限制 (memory_limit
)至 64 MB 内存,如果使用附加模块,建议安装 128 MB。
Drupal 可以使用 Apache 或 Nginx 作为 Web 服务器,并使用 MySQL、PostgreSQL 或 SQLite 作为数据库。
我们将使用 Nginx 和 MySQL 安装 Drupal。
安装
将已安装的软件包更新到最新版本:
sudo dnf update -y
让我们为 http/80 和 https/443 端口的传入流量添加永久权限:
sudo firewall-cmd --permanent --add-service=http
sudo firewall-cmd --permanent --add-service=https
应用新的防火墙规则:
sudo systemctl reload firewalld
安装 Nginx:
sudo dnf install nginx -y
让我们启动并启用 Nginx 服务器:
sudo systemctl start nginx
sudo systemctl enable nginx
由于 Centos 主存储库当前使用 PHP 7.2,因此我们使用 PHP 7.4(Drupal 9 的最低版本)添加 REMI 存储库。
为此,请添加 EPEL 存储库(REMI 存储库需要):
rpm -Uvh https://dl.fedoraproject.org/pub/epel/epel-release-latest-8.noarch.rpm
让我们添加 REMI 存储库:
sudo dnf install -y https://rpms.remirepo.net/enterprise/remi-release-8.rpm
启用 php:remi-7.4 模块来安装 php 7.4:
sudo dnf module enable php:remi-7.4 -y
安装 php-fpm 和 php-cli:
sudo dnf install -y php-fpm php-cli
安装 Drupal 工作所需的 PHP 模块:
sudo dnf install -y php-mysqlnd php-date php-dom php-filter php-gd php-hash php-json php-pcre php-pdo php-session php-simplexml php-spl php-tokenizer php-xml
我们还将安装推荐的 PHP 模块 mbstring opcache:
sudo dnf install -y php-mbstring php-opcache
安装MySQL服务器:
sudo dnf install mysql-server -y
启用并启动 MySQL 服务器:
sudo systemctl start mysqld
sudo systemctl enable mysqld
由于我们正在为 VDS 制作模板,并且它们可能很慢,因此我们将添加 30 秒的 mysqld 启动延迟,否则在初始系统启动期间启动服务器可能会出现问题:
sudo sed -i '/Group=mysql/a
ExecStartPre=/bin/sleep 30
' /usr/lib/systemd/system/mysqld.service
让我们通过更改 /etc/php-fpm.d/www.conf 来更改 nginx 运行的组和用户:
sudo sed -i --follow-symlinks 's/user = apache/user = nginx/g' /etc/php-fpm.d/www.conf
sudo sed -i --follow-symlinks 's/group = apache/group = nginx/g' /etc/php-fpm.d/www.conf
相应地将 PHP 会话目录的所有者更改为 nginx:
sudo chown -R nginx. /var/lib/php/session
让我们从 /etc/nginx/nginx.conf 配置文件中删除注释行(这样 sed 就不会出现双重命中):
sudo sed -i -e '/^[ t]*#/d' /etc/nginx/nginx.conf
将 gzip 压缩设置添加到 /etc/nginx/nginx.conf
sudo sed -i '/types_hash_max_size 2048;/a
gzip on;
gzip_static on;
gzip_types text/plain text/css application/json application/x-javascript text/xml application/xml application/xml+rss text/javascript application/javascript image/x-icon image/svg+xml application/x-font-ttf;
gzip_comp_level 9;
gzip_proxied any;
gzip_min_length 1000;
gzip_disable "msie6";
gzip_vary on;
' /etc/nginx/nginx.conf
让我们将index.php索引文件的设置添加到/etc/nginx/nginx.conf中:
sudo sed -i '/ root /usr/share/nginx/html;/a
index index.php index.html index.htm;
' /etc/nginx/nginx.conf
让我们通过 php-fpm 套接字添加默认服务器处理 php 的设置,禁用静态文件的日志,增加过期时间,禁用 favicon.ico 和 robots.txt 的访问和错误日志,并拒绝访问 .ht 文件每个人:
sudo sed -i '/ location / {/a
try_files $uri $uri/ /index.php?q=$uri&$args;
}
location ~* ^.+.(js|css|png|jpg|jpeg|gif|ico|woff)$ {
access_log off;
expires max;
}
location ~ .php$ {
try_files $uri =404;
fastcgi_pass unix:/run/php-fpm/www.sock;
fastcgi_index index.php;
include fastcgi_params;
fastcgi_intercept_errors on;
fastcgi_ignore_client_abort off;
fastcgi_connect_timeout 60;
fastcgi_send_timeout 180;
fastcgi_read_timeout 180;
fastcgi_buffer_size 128k;
fastcgi_buffers 4 256k;
fastcgi_busy_buffers_size 256k;
fastcgi_temp_file_write_size 256k;
}
location = /favicon.ico {
log_not_found off;
access_log off;
}
location = /robots.txt {
allow all;
log_not_found off;
access_log off;
}
location ~ /.ht {
deny all;' /etc/nginx/nginx.conf
安装安装 certbot 所需的 wget:
sudo dnf install wget -y
从场外下载 certbot 可执行文件:
cd ~
wget https://dl.eff.org/certbot-auto
将 certbot 移动到 /usr/local/bin/:
mv certbot-auto /usr/local/bin/certbot-auto
并将权利和所有权分配给 root:
chown root /usr/local/bin/certbot-auto
chmod 0755 /usr/local/bin/certbot-auto
安装 certbot 的依赖项并在此阶段停止它(答案:Y、c):
certbot-auto
从场外下载最新版本 Drupal 9 的存档:
cd ~
wget https://www.drupal.org/download-latest/tar.gz
安装 tar 以解压存档:
sudo dnf install tar -y
删除/usr/share/nginx/html/目录下的默认文件:
rm -rf /usr/share/nginx/html/*
将文件解压到Web服务器目录:
tar xf tar.gz -C /usr/share/nginx/html/
将文件从子目录移动到 Web 服务器的根目录:
mv /usr/share/nginx/html/drupal-9.0.7/* /usr/share/nginx/html/
删除子目录:
rm -rf /usr/share/nginx/html/drupal-9.0.7
删除包含安装文件的存档:
rm -f ./tar.gz
设置 nginx 文件的所有者:
chown -R nginx. /usr/share/nginx/html
在此阶段,我们将关闭服务器并拍摄快照:
shutdown -h now
从快照启动 VDS 后,我们将通过运行以下脚本来执行 MySQL 服务器的初始设置:
mysql_secure_installation
启用密码验证器:
Would you like to setup VALIDATE PASSWORD component? : y
设置MySQL root用户密码:
New password:
Re-enter new password:
删除匿名用户:
Remove anonymous users? (Press y|Y for Yes, any other key for No) : y
让我们阻止 root 远程连接:
Disallow root login remotely? (Press y|Y for Yes, any other key for No) : y
让我们删除测试数据库:
Remove test database and access to it? (Press y|Y for Yes, any other key for No) : y
重新加载权限表:
Reload privilege tables now? (Press y|Y for Yes, any other key for No) : y
之后,为了完成安装,我们可以去
在这个地址我们会看到一个Drupal安装的页面。
选择要使用的语言。 例如:俄语。 点击“保存并继续”
让我们选择一个安装配置文件(演示仅用于熟悉系统)。 在我们的例子中,让它成为“标准”。
在下一页上,为数据库命名,例如“drupal”。 指定数据库用户名 root 以及启动 mysql_secure_installation 时给他的密码。 单击“保存并继续”。
让我们等待翻译的安装和更新完成(该过程可能需要几分钟)。
指定站点名称,设置站点电子邮件(代表将收到哪个站点通知)、Drupal 管理员帐户的登录名、密码和电子邮件。 我们还将在区域设置中设置国家和时区。 并单击“保存并继续”完成安装。
之后,您可以使用创建的Drupal管理员登录名和密码进入控制面板。
HTTPS 设置(可选)
要配置 HTTPS,VDS 必须具有有效的 DNS 名称,在中指定
/etc/nginx/nginx.conf
在服务器部分中的服务器名称(例如):
server_name domainname.ru;
重启nginx:
service nginx restart
让我们启动 certbot:
sudo /usr/local/bin/certbot-auto --nginx
输入您的电子邮件,同意服务条款 (A),订阅时事通讯(可选)(N),选择您要为其颁发证书的域名(全部输入)。
如果一切顺利,我们将看到一条有关证书颁发和服务器设置成功的消息:
Congratulations! You have successfully enabled ...
之后,端口 80 上的连接将被重定向到 443 (https)。
添加到/etc/crontab以自动更新证书:
# Cert Renewal
30 2 * * * root /usr/local/bin/certbot-auto renew --post-hook "nginx -s reload"
设置可信主机安全(推荐)
此设置旨在作为动态 base_url 检测问题的解决方案,并旨在防止 HTTP HOST 标头攻击(当您的网站认为是其他人时)。
为此,您需要在设置文件中指定站点的受信任域名。
在文件中
/usr/share/nginx/html/sites/default/settings.php
取消注释或添加具有实际站点名称模式的设置,例如:
$settings['trusted_host_patterns'] = [
'^www.mydomain.ru$',
];
安装 PHP APCu(推荐)
Drupal 支持 APCu - 替代 PHP 用户缓存,版本 8 和 9 比以前的版本更频繁地使用 APCu 作为短期本地缓存。 默认缓存大小 (32 MB) 适合大多数站点,并且不能超过 512 MB。
要激活,请安装 PHP APCu 模块:
dnf -y install php-pecl-apcu
重新启动 nginx 和 php-fpm:
service nginx restart
service php-fpm restart
在使用俄语和APCu以及推荐的缓存大小的情况下,您可以在控制面板中看到一条警告,指出分配的缓存内存的大小与推荐的大小不同,但实际上一切正常,并且不正确警告很可能会在下次更新中得到修复。
或者,如果警告伤害眼睛,您可以使用
我们想提醒您,您也可以为我们制作图像
参与方式有三种选择。
自行准备图像并获得 3000 卢布的余额
如果您准备好立即投入战斗并塑造您所缺乏的形象,我们将在您的内部余额中存入 3000 卢布 - 您可以将其花在服务器上。
如何创建您的形象:
- 在我们这里创建一个帐户
在线 - 告诉支持人员您将创建和测试图像
- 我们将向您赠送 3000 卢布并启用创建快照的功能
- 订购具有干净操作系统的虚拟服务器
- 在此 VPS 上安装软件并进行设置
- 编写软件部署的说明或脚本
- 为配置的服务器创建快照
- 通过在“服务器模板”下拉列表中选择之前创建的快照来订购新的虚拟服务器
- 服务器创建成功后,将第6步收到的材料转发给技术支持
- 如果出现错误,您可以向支持人员检查原因并重复设置
对于企业主:提供您的软件
如果您是在 VPS 上部署和使用的软件开发人员,那么我们可以将您纳入市场。 这就是我们如何帮助您吸引新客户、流量和知名度的方式。
请在评论中告诉我们您错过了哪张图片?
我们会自己准备
来源: habr.com