Heim  >  Artikel  >  Backend-Entwicklung  >  Beispiele zur Erläuterung der PHP-Implementierung der Git-Bereitstellung

Beispiele zur Erläuterung der PHP-Implementierung der Git-Bereitstellung

小云云
小云云Original
2017-12-20 10:20:401672Durchsuche

Obwohl ich Git immer für die Versionsverwaltung und die Git-Projektbereitstellung verwendet habe, habe ich mich kürzlich entschlossen, mehr über die Git-Bereitstellungsmethode in PHP zu erfahren. Das Tutorial ist durch Beispielcode sehr detailliert. Freunde, die es benötigen, können darauf zurückgreifen. Ich hoffe, es kann jedem helfen.

Hintergrund

Auf einer kleinen Site ist es sehr praktisch, Git direkt zum Bereitstellen von PHP-Code zu verwenden. Ihre Remote-Site und Ihr lokales Repository verfügen über eine Versionskontrolle, um Probleme zu verfolgen oder Rollbacks durchzuführen sehr einfach.

Da ich in einem kleinen Unternehmen arbeite, verwendet das ursprüngliche System immer noch den herkömmlichen FTP-Upload und die Bereitstellung. Die Bereitstellung ist zu mühsam und es ist schwierig, den Online-Code zu steuern. Ich habe im Internet nach einem Git-Bereitstellungs-Tutorial gesucht und dabei auf viele Fallstricke gestoßen. Jetzt veröffentliche ich den gesamten Prozess und hoffe, dass er allen weiterhelfen kann. Schauen wir uns die Details an Einführung.

Kontobezogen

useradd -m git //新增git账号
ssh-keygen //密钥生成,如果已经有了可略过
su git //切换至git账号
cd ~ //切换到git账号根目录
mkdir .ssh //创建.ssh目录
cat /密钥存放目录/xxx.pub >> ~/.ssh/authorized_keys //设置公钥

Achten Sie hier unbedingt auf Berechtigungsprobleme, da sonst die Schlüsselanmeldung nicht wirksam ist. Die entsprechenden Berechtigungen für jeden Ordner sind wie folgt

.ssh文件夹权限 700
id_rsa 600
id_rsa.pub 644
authorized_keys 600

Dateiberechtigungseinstellungen

Fügen Sie Git und den Benutzer, der Nginx oder Apache auf der Site ausführt, derselben Benutzergruppe hinzu, z. B. www

vim /etc/passwd Suchen Sie das Git-Konto und das WWW-Konto, ändern Sie die Gruppen-ID des Git-Kontos so, dass sie mit der WWW-Gruppen-ID übereinstimmt.

Setzen Sie den Websitebesitzer auf Git und die Benutzergruppe auf www //Angenommen, dass Nginx und Git beide zur www-Benutzergruppe gehören

Verzeichnisberechtigungen sind auf 775 und Dateiberechtigungen auf 664 eingestellt

Warehouse-Code

Serverseitig

cd 站点目录
git init //初始化目录

Git-Konfiguration

git config receive.denyCurrentBranch ignore //设置仓库接受代码提交

Sudo passwortfrei einstellen

vim /etc/sudoers
# Defaults secure_path 中若没有你要的命令,要注意添加
# php的命令默认需要在 secure_path最后面添加 :/usr/local/php/bin"
在 root ALL=(ALL) ALL 下面一行添加
git ALL=(ALL) NOPASSWD:ALL 
# 保存退出 ,这样针对laravel 要重启队列命令就可以使用了.
# sudo php artisan queue:restart

Hook-Einstellungen

cd .git/hooks //切换至站点钩子目录
touch post-receive //创建接收提交时钩子
// 钩子文件内容如下:
#!/bin/sh
# 设置账号创建文件的默认权限
umask 002 
unset GIT_DIR
cd ..
git checkout -f
# 执行PHP钩子逻辑
/usr/bin/curl http(s)://域名/钩子文字位置/hook.php
# 如果有使用laravel队列则需要重启队列进程,让新代码生效
# sudo php artisan queue:restart
exit 0

hook.php-Inhalt

<?php
/**
 * git上传执行钩子
 */
//TODO 安全限制
//TODO 其他钩子行为
// 清除opcache
if (version_compare(PHP_VERSION, &#39;5.5.0&#39;, &#39;>=')) {
 opcache_reset();
}

Hook-Ausführungsberechtigungen hinzufügen

chmod a+x .git/hooks/post-receive

Lokaler Code

git remote add 远程仓库名称 ssh://git@IP地址:/站点目录 //添加远程仓库
git push 远程仓库名称 master

Achten Sie besonders auf

von Benutzern hochgeladene Bilder. Das Verzeichnis muss ignoriert werden, da sonst beim Löschen nicht verfolgter Dateien möglicherweise einige Dateien gelöscht werden, was zu katastrophalen Folgen führt

Verwandte Empfehlungen:

PHP mit Git-Bereitstellungsumgebung

Einige Anwendungsfälle von Git

Detaillierte Erläuterung der Javascript-Datentypen und des Git-Verwendungscodes

Das obige ist der detaillierte Inhalt vonBeispiele zur Erläuterung der PHP-Implementierung der Git-Bereitstellung. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn