Detailliertes Tutorial zur Implementierung der Git-Bereitstellung in PHP

jacklove
Freigeben: 2023-04-02 15:50:01
Original
2095 Leute haben es durchsucht

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 in Not können darauf zurückgreifen.

Hintergrund

Auf einer kleinen Site ist es sehr praktisch, Git direkt zum Bereitstellen von PHP-Code, Ihrer Remote-Site usw. zu verwenden Lokale Versionsbibliotheken verfügen über eine Versionskontrolle, die es einfach macht, Probleme aufzuspüren oder ein Rollback durchzuführen.

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 poste ich den gesamten Prozess und hoffe, dass er allen weiterhelfen kann. Schauen wir uns die detaillierte Einführung an .

Kontobezogen

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

Achten Sie unbedingt auf Berechtigungsprobleme hier, Andernfalls wird die Schlüsselanmeldung nicht wirksam:

.ssh文件夹权限 700
id_rsa 600
id_rsa.pub 644
authorized_keys 600
Nach dem Login kopieren

Dateiberechtigungseinstellungen

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

vim /etc/passwd Suchen Sie das Git-Konto und das WWW-Konto und gruppieren Sie das Git-Konto. Das Logo wird so geändert, dass es mit dem WWW-Gruppenlogo übereinstimmt.

Der Websitebesitzer ist auf Git und die Benutzergruppe auf www eingestellt //Angenommen, dass Nginx und Git beide zur www-Benutzergruppe gehören

Verzeichnisberechtigungen sind auf 775 und Dateiberechtigungen auf 664 eingestellt

Warehouse Code

Serverseite

cd 站点目录
git init //初始化目录
Nach dem Login kopieren

Git-Konfiguration

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

Sudo passwortfrei setzen

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
Nach dem Login kopieren

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
Nach dem Login kopieren

hook.php-Inhalt

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

Hook-Ausführungsberechtigungen hinzufügen

chmod a+x .git/hooks/post-receive
Nach dem Login kopieren

Nativer Code

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

Besondere Aufmerksamkeit

Das vom Benutzer hochgeladene Bildverzeichnis muss ignoriert werden, da es sonst möglicherweise gelöscht wird, wenn nicht verfolgte Dateien gelöscht werden, was zu katastrophalen Ergebnissen führt

Zusammenfassung

Erklärung und Analyse des in PHP implementierten binären Suchalgorithmus

Ein Beispiel für den in PHP implementierten Halbsuchalgorithmus

Ein Beispiel für einen in PHP implementierten String-Matching-Algorithmus

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

Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
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
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage