Heim >Backend-Entwicklung >PHP-Tutorial >PHP-Online-Update-Lösung
Das aktuelle Nachfrageszenario sieht wie folgt aus:
Ich habe eine Erweiterung entwickelt, die auf verschiedenen Open-Source-CMS-Systemen wie WordPress, Discuz usw. läuft.
Wenn ein Benutzer nun unser Produkt installiert und verwendet, stellen wir eine neue Version aus und fordern den Benutzer zum Aktualisieren auf. Der Benutzer klickt auf eine Schaltfläche und wird sofort auf die neue Version aktualisiert. Die Nutzer zeigten sich zufrieden.
Die Benutzer sind zufrieden, aber um diese Aktion hier abzuschließen, müssen wir ein automatisches Upgrade-System für jedes Open-Source-CMS entwickeln. Ich habe dieses System schon einmal entwickelt. Es ist ziemlich mühsam, Versionen zu vergleichen, Dateien herunterzuladen usw. Ein einzelnes CMS ist in Ordnung, aber in Zukunft wird es auf viele CMS erweitert. Wir alle müssen dieses Ding für diesen Satz von CMS entwickeln , das ist eine Menge Arbeit. Es ist riesig. Daher hoffe ich nun, einen gemeinsamen Mechanismus zu entwickeln, der auf alle CMS-Systeme angewendet werden kann. Gibt es eine gute Methode?
------------------------
Ich denke jetzt über einen Weg nach. Die Schwierigkeit bei der Implementierung dieser Funktion besteht zunächst darin, dass es für eine PHP-Datei unmöglich ist, sich selbst zu ersetzen. Das heißt, es ist für diese laufende PHP-Datei unmöglich, sich selbst zu löschen oder ihren eigenen Quellcode zu ändern.
Es muss also eine Datei geben, die die Rolle spielt, andere zu ändern. Seine eigenen Dinge ändern sich nicht, und seine Existenz besteht darin, andere zu verändern.
Zum Beispiel gibt es unter dieser Erweiterung drei Dateien a, b und c. Wenn der Benutzer auf „Upgrade“ klickt, wird eine Ajax-Anfrage gesendet, um direkt auf die C-Datei zuzugreifen und sie auszuführen. Die C-Datei wird unabhängig ausgeführt und ist nicht von anderen Dateien abhängig. Auf diese Weise kann er die Dateien a und b ändern, löschen usw. und so den Zweck der automatischen Aktualisierung erreichen. Für alle CMS-Erweiterungen muss ich nur eine Datei c unter jedem Verzeichnis ablegen, und das ist in Ordnung Die Arbeitsbelastung wurde exponentiell reduziert?
Ist diese Lösung machbar?
Das aktuelle Nachfrageszenario sieht wie folgt aus:
Ich habe eine Erweiterung entwickelt, die auf verschiedenen Open-Source-CMS-Systemen wie WordPress, Discuz usw. läuft.
Wenn ein Benutzer nun unser Produkt installiert und verwendet, stellen wir eine neue Version aus und fordern den Benutzer zum Aktualisieren auf. Der Benutzer klickt auf eine Schaltfläche und wird sofort auf die neue Version aktualisiert. Die Nutzer zeigten sich zufrieden.
Die Benutzer sind zufrieden, aber um diese Aktion hier abzuschließen, müssen wir ein automatisches Upgrade-System für jedes Open-Source-CMS entwickeln. Ich habe dieses System schon einmal entwickelt. Es ist ziemlich mühsam, Versionen zu vergleichen, Dateien herunterzuladen usw. Ein einzelnes CMS ist in Ordnung, aber in Zukunft wird es auf viele CMS erweitert. Wir alle müssen dieses Ding für diesen Satz von CMS entwickeln , das ist eine Menge Arbeit. Es ist riesig. Daher hoffe ich nun, einen gemeinsamen Mechanismus zu entwickeln, der auf alle CMS-Systeme angewendet werden kann. Gibt es eine gute Methode?
------------------------
Ich denke jetzt über einen Weg nach. Die Schwierigkeit bei der Implementierung dieser Funktion besteht zunächst darin, dass es für eine PHP-Datei unmöglich ist, sich selbst zu ersetzen. Das heißt, es ist für diese laufende PHP-Datei unmöglich, sich selbst zu löschen oder ihren eigenen Quellcode zu ändern.
Es muss also eine Datei geben, die die Rolle spielt, andere zu ändern. Seine eigenen Dinge ändern sich nicht, und seine Existenz besteht darin, andere zu verändern.
Zum Beispiel gibt es unter dieser Erweiterung drei Dateien a, b und c. Wenn der Benutzer auf „Upgrade“ klickt, wird eine Ajax-Anfrage gesendet, um direkt auf die C-Datei zuzugreifen und sie auszuführen. Die C-Datei wird unabhängig ausgeführt und ist nicht von anderen Dateien abhängig. Auf diese Weise kann er die Dateien a und b ändern, löschen usw. und so den Zweck der automatischen Aktualisierung erreichen. Für alle CMS-Erweiterungen muss ich nur eine Datei c unter jedem Verzeichnis ablegen, und das ist in Ordnung Die Arbeitsbelastung wurde exponentiell reduziert?
Ist diese Lösung machbar?
Mir ist eine allgemeine Idee eingefallen:
Zunächst empfiehlt es sich, es in Hauptversions-Updates und Patch-Updates zu unterteilen. Wenn das Hauptversions-Update komplizierter ist, müssen Sie die Datei trotzdem herunterladen und die Datei manuell überschreiben.
Kleine Versionsaktualisierungen können eine allgemeine Update-Bereitstellungsmethode erstellen:
Der Client aktualisiert die Anforderung einheitlich an die zentrale serverseitige Schnittstelle oder Eintragsdatei zur Verarbeitung von Aktualisierungen. Über die Eintragsdatei passt er die Daten der lokalen Umgebungsserie dynamisch an Vom Client über die Eintragsdatei übermittelt. Generieren Sie ein Upgrade-Paket und stellen Sie die JSON-Konfigurationsdatei bereit. Nach dem Empfang liest der Client die Datenbank, ersetzt Dateien usw. Auf diese Weise muss der Server nur eine kontinuierliche Wartung durchführen verschiedene CMS-Upgrade-Regeln nach Versions-Upgrades.
Trotzdem ist die Arbeitsbelastung immer noch riesig!
composer
!composer
!composer
!!!!!!!!!!
Mein Denken ist wirklich starr.
Da PHP sich nicht selbst ändern kann, ändern Sie die Konfigurationsdatei oder die Datenbank, und das Problem wird gelöst.