私の環境では、次のスクリプトを使用して以下を実行します。
- Nginx サイト構成を作成します。
- 対応する Let'sEncrypt SSL 証明書を生成します。
sites-default
私のディレクトリとサイト構成の間にシンボリックリンクを作成します。- サーバーを再起動します。
私のコード:
#!/bin/sh
for domain; do
> "/etc/nginx/sites-available/${domain}.conf" cat <<EOF
server {
root /var/www/html/${DOMAIN};
server_name ${DOMAIN} www.${DOMAIN};
location ~ /\.ht {
deny all;
}
location / {
index index.php index.html index.htm fastcgi_index;
try_files $uri $uri =404 $uri/ /index.php?$args;
}
location ~* \.(jpg|jpeg|png|gif|ico|css|js|ttf|woff|pdf)$ {
expires 365d;
}
location ~ \.php$ {
fastcgi_pass unix:/var/run/php/php7.0-fpm.sock;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
include fastcgi_params;
}
}
EOF
sudo ln -s /etc/nginx/sites-available/${domain} /etc/nginx/sites-enabled/
#########################################################################
certbot --nginx -d ${DOMAIN} -d www.${DOMAIN}
done
systemctl restart nginx.service # Create Webapp Substrate.
このコードを改善する方法と理由は次のとおりです。
長いハッシュマーク行があるところに次のコマンドを挿入したいと思います。
echo 'create database ${DOMAIN}; create user "${DOMAIN}"@"localhost" identified by "mypassword"; grant all privileges on ${DOMAIN}.* to ${DOMAIN};' | mysql -u root -p
このコマンドを追加すると、スクリプトは手順4の代わりに手順5を実行するように変更されます。
- Nginx サイト構成を作成します。
- 対応する Let'sEncrypt SSL 証明書を生成します。
sites-default
私のディレクトリとサイト構成の間にシンボリックリンクを作成します。- localhostでのみ機能し、同じ名前のデータベースを持つすべての権限を持ち、認証されたデータベースユーザーを追加します。
- サーバーを再起動します。
私の質問:
ご覧のとおり、${DOMAIN}
私はecho
。〜しなければならないここでも同じパラメータを渡します。そうしないと、データベースのユーザー名または関連データベースが自分のサイト構成に合わず、WordPressベースのサイトが起動しなくなります。
Bashでこれは論理的ですか?それとも別のアプローチをとりますか?
これを明確にするためにパラメータがecho
。
答え1
これを行うには、以下を行う必要はありませんecho
。
mysql -u root -ppass <<EOF
create database ${DOMAIN};
create user "${DOMAIN}"@"localhost" identified by "mypassword";
grant all privileges on ${DOMAIN}.* to ${DOMAIN};
EOF
トピックを見るなぜprintfがechoより優れているのですか?
答え2
質問された内容は次のとおりです。Bash パラメータの置換。このecho
コマンドはここでは効果がありません。使ってるみたいですねアポストロフィ変える二重引用符、文字列内のパラメータ置換を抑制します。一重引用符の代わりに二重引用符を使用して文字列に含める二重引用符をエスケープするには、バックスラッシュを使用します。たとえば、次のようになります。
echo "create database ${DOMAIN}; create user \"${DOMAIN}\"@\"localhost\" identified by \"mypassword\"; grant all privileges on ${DOMAIN}.* to ${DOMAIN};"