Deployment Laraknife Projekt: Unterschied zwischen den Versionen
Zur Navigation springen
Zur Suche springen
(→nginx) |
|||
(3 dazwischenliegende Versionen desselben Benutzers werden nicht angezeigt) | |||
Zeile 18: | Zeile 18: | ||
<syntaxhighlight lang="bash"> | <syntaxhighlight lang="bash"> | ||
PROJ=taskx | PROJ=taskx | ||
DOMAIN=$PROJ.hamatoma.de | |||
REPO=$PROJ.git | REPO=$PROJ.git | ||
cd /srv/www | cd /srv/www | ||
git config --global --add safe.directory /home/git/repo/$REPO | git config --global --add safe.directory /home/git/repo/$REPO | ||
echo "= Note: no checkout. Coming later | |||
git clone /home/git/repo/$REPO | git clone /home/git/repo/$REPO | ||
sudo chown -R www-data:www-data $PROJ | sudo chown -R www-data:www-data $PROJ | ||
cd $ | mv $PROJ $DOMAIN | ||
cd $DOMAIN | |||
sudo -u www-data git checkout main | sudo -u www-data git checkout main | ||
dbtool create-db-and-user lrv$PROJ lrv$PROJ TopSecret | dbtool create-db-and-user lrv$PROJ lrv$PROJ TopSecret | ||
DB=lrv$PROJ | DB=lrv$PROJ | ||
PW=TopSecret | PW=TopSecret | ||
dbtool create-webapp-configuration $DOMAIN $(pwd) $DB $DB $PW | dbtool create-webapp-configuration $DOMAIN $(pwd) $DB $DB $PW | ||
mysql -u lrv$PROJ "-p$PW" lrv$PROJ <resources/db/lrv$PROJ.sql | |||
mkdir -pv storage/logs storage/framework/{cache,sessions,views} storage/app/public | mkdir -pv storage/logs storage/framework/{cache,sessions,views,export} storage/app/public/export | ||
chown -R www-data:www-data storage | chown -R www-data:www-data storage | ||
ln -s ../storage/app/public/export public/export | |||
cp .env.example .env | cp .env.example .env | ||
# .env anpassen! | # .env anpassen! | ||
chown www-data .env | chown www-data .env | ||
sudo -u www-data composer update | |||
sudo -u www-data npm install vite laravel-vite-plugin | |||
sudo -u www-data php artisan key:generate | sudo -u www-data php artisan key:generate | ||
sudo -u www-data php artisan config:cache | sudo -u www-data php artisan config:cache |
Aktuelle Version vom 1. Dezember 2024, 18:08 Uhr
Links
Zielsetzung
Ein Projekt ist lokal erstellt und soll jetzt auf einen Server migriert werden.
Auf dem lokalen System
- Datenbankinhalt speichern:
PROJ=taskx
mkdir -p resources/db
cd resources/db
sudo mysqldump lrv$PROJ | gzip > lrv$PROJ.sql.gz
Auf dem Server
- Als User root:
PROJ=taskx
DOMAIN=$PROJ.hamatoma.de
REPO=$PROJ.git
cd /srv/www
git config --global --add safe.directory /home/git/repo/$REPO
echo "= Note: no checkout. Coming later
git clone /home/git/repo/$REPO
sudo chown -R www-data:www-data $PROJ
mv $PROJ $DOMAIN
cd $DOMAIN
sudo -u www-data git checkout main
dbtool create-db-and-user lrv$PROJ lrv$PROJ TopSecret
DB=lrv$PROJ
PW=TopSecret
dbtool create-webapp-configuration $DOMAIN $(pwd) $DB $DB $PW
mysql -u lrv$PROJ "-p$PW" lrv$PROJ <resources/db/lrv$PROJ.sql
mkdir -pv storage/logs storage/framework/{cache,sessions,views,export} storage/app/public/export
chown -R www-data:www-data storage
ln -s ../storage/app/public/export public/export
cp .env.example .env
# .env anpassen!
chown www-data .env
sudo -u www-data composer update
sudo -u www-data npm install vite laravel-vite-plugin
sudo -u www-data php artisan key:generate
sudo -u www-data php artisan config:cache
nginx
PROJ=oo4f
DOMAIN=$PROJ.hamatoma.de
cd /etc/nginx/sites-available
cat <<EOS >$DOMAIN
server{
listen 80;
server_name $DOMAIN;
include snippets/letsencrypt.conf;
root /srv/www/$DOMAIN;
location / {
return 301 https://\$server_name\$request_uri; # enforce https
}
}
server {
listen 443 ssl http2;
listen [::]:443 ssl http2;
server_name $DOMAIN;
root /srv/www/$DOMAIN/public;
ssl_certificate /etc/letsencrypt/live/latest/fullchain.pem;
ssl_certificate_key /etc/letsencrypt/live/latest/privkey.pem;
#ssl_certificate /etc/ssl/certs/$DOMAIN.pem;
#ssl_certificate_key /etc/ssl/private/$DOMAIN.key;
client_max_body_size 1G;
access_log /var/log/nginx/a_$PROJ.log;
error_log /var/log/nginx/e_$PROJ.log;
add_header X-Frame-Options "SAMEORIGIN";
add_header X-Content-Type-Options "nosniff";
index index.php;
charset utf-8;
location / {
try_files \$uri \$uri/ /index.php?\$query_string;
}
location = /favicon.ico { access_log off; log_not_found off; }
location = /robots.txt { access_log off; log_not_found off; }
error_page 404 /index.php;
location ~ \.php\$ {
fastcgi_pass unix:/var/run/php/php8.2-fpm.sock;
fastcgi_param SCRIPT_FILENAME \$realpath_root\$fastcgi_script_name;
include fastcgi_params;
}
location ~ /\.(?!well-known).* {
deny all;
}
}
EOS
cd ../sites-enabled
ln -sv ../sites-available/$DOMAIN .