go-Sprache kann programmiert werden. Die Go-Sprache ist eine statisch stark typisierte, kompilierte, gleichzeitige Programmiersprache mit Garbage-Collection-Funktion, die von Google entwickelt wurde. Die Go-Sprache hat viele Verwendungsmöglichkeiten und kann für Netzwerkprogrammierung, Systemprogrammierung, gleichzeitige Programmierung und verteilte Programmierung verwendet werden. Als Server-Programmiersprache eignet sich die Go-Sprache sehr gut für die Verarbeitung von Protokollen, die Datenverpackung, die Verarbeitung virtueller Maschinen, Dateisysteme, verteilte Systeme, Datenbankagenten usw. Sie kann auch für die Netzwerkprogrammierung wie Webanwendungen, API-Anwendungen usw. verwendet werden Anwendungen herunterladen.
Die Betriebsumgebung dieses Tutorials: Windows 7-System, GO Version 1.18, Dell G3-Computer.
Go-Sprache, auch bekannt als Golang, ist eine von Google entwickelte statisch stark typisierte, kompilierte, gleichzeitige und Garbage-Collection-Programmiersprache.
Go-Sprache (oder Golang) entstand 2007 und wurde 2009 offiziell veröffentlicht. Go ist eine sehr junge Sprache und ihr Hauptziel besteht darin, „die Entwicklungsgeschwindigkeit dynamischer Sprachen wie Python mit der Leistung und Sicherheit kompilierter Sprachen wie C/C++ zu kombinieren“.
Go-Sprache ist ein weiterer Versuch des Programmiersprachendesigns und eine wesentliche Verbesserung gegenüber C-ähnlichen Sprachen. Sie ermöglicht Ihnen nicht nur den Zugriff auf das zugrunde liegende Betriebssystem, sondern bietet auch leistungsstarke Netzwerkprogrammierung und Unterstützung für gleichzeitige Programmierung. Die Go-Sprache hat viele Verwendungsmöglichkeiten und kann für die Netzwerkprogrammierung, Systemprogrammierung, gleichzeitige Programmierung und verteilte Programmierung verwendet werden:
Serverprogrammierung Wenn Sie zuvor C oder C++ für diese Aufgaben verwendet haben, ist Go dafür sehr gut geeignet B. Verarbeitungsprotokolle, Datenpaketierung, Verarbeitung virtueller Maschinen, Dateisystem usw.
Verteilte Systeme, Datenbankbroker, Middleware usw. wie Etcd.
Netzwerkprogrammierung wird derzeit am häufigsten verwendet, einschließlich Webanwendungen, API-Anwendungen und Download-Anwendungen. Das integrierte Net/http-Paket von Go implementiert im Grunde alle Netzwerkfunktionen, die wir normalerweise verwenden.
Die Einführung der Go-Sprache zielt darauf ab, die Komplexität des Codes zu reduzieren, ohne die Anwendungsleistung zu beeinträchtigen. Sie bietet derzeit die Vorteile einer „einfachen Bereitstellung, einer guten Parallelität, eines guten Sprachdesigns und einer guten Ausführungsleistung“. Alle Projekte wurden mit der Go-Sprache entwickelt.
Viele wichtige Open-Source-Projekte werden mit der Go-Sprache entwickelt, darunter Docker, Go-Ethereum, Thrraform und Kubernetes.
Welche Unternehmen oder Projekte im In- und Ausland verwenden die Go-Sprache?
Nach der Veröffentlichung von Go begannen viele Unternehmen, insbesondere Cloud-Computing-Unternehmen, Go zur Rekonstruktion ihrer Infrastruktur zu verwenden, und viele von ihnen nutzten es direkt Go für die Entwicklung. Docker ist in vollem Gange und wird mit Go entwickelt.
Es gibt viele Open-Source-Projekte, die mit der Go-Sprache entwickelt wurden. Frühe Open-Source-Projekte in der Go-Sprache implementierten nur die C-Sprachbibliotheksbindung, während viele spätere Projekte die Go-Sprache für die re-native Implementierung verwendeten trug auch zur Entstehung einer großen Anzahl nativer Entwicklungsprojekte bei, die die Go-Sprache verwenden.
Cloud-Computing-Infrastrukturbereich
Repräsentative Projekte: Docker, Kubernetes, etcd, Konsul, Cloudflare CDN, Qiniu Cloud Storage usw.
Basissoftware
Repräsentative Projekte: Tidb, Influxdb, Cockroachdb usw.
Microservices
Repräsentative Projekte: Go-Kit, Micro, Typhon der Monzo Bank, Bilibili usw.
Internet-Infrastruktur
Repräsentative Projekte: Ethereum, Hyperledger usw.
Einige ausländische Unternehmen, die Go verwenden, wie Google, Docker, Apple, Cloud Foundry, CloudFlare, Couchbase, CoreOS, Dropbox, MongoDB, AWS und andere Unternehmen;
Inländische Unternehmen, die Go-Entwicklung verwenden: wie Alibaba Cloud CDN, Baidu, Xiaomi, Qiniu, PingCAP, Huawei, Kingsoft, Cheetah Mobile, Ele.me und andere Unternehmen.
Docker
Docker ist eine Virtualisierungstechnologie auf Betriebssystemebene, die zwischen Betriebssystemen und Anwendungen isolieren kann und auch als Container bezeichnet werden kann. Docker kann schnell eine oder mehrere Instanzen auf einem physischen Server ausführen. Ein auf lxc basierendes virtuelles Verpackungstool kann den Aufbau einer PAAS-Plattform realisieren. Starten Sie beispielsweise ein CentOS-Betriebssystem und beenden Sie es, nachdem Sie Anweisungen in seiner internen Befehlszeile ausgeführt haben. Der gesamte Prozess ist so effizient wie das Betriebssystem selbst.
Go Language
Der frühe Quellcode von Go Language wurde in C-Sprache und Assemblersprache geschrieben. Ab der Go-Version 1.5 ist es vollständig in der Go-Sprache selbst geschrieben. Der Quellcode der Go-Sprache ist von großer Referenzbedeutung für das Verständnis der zugrunde liegenden Planung der Go-Sprache. Lesern, die ein tiefgreifendes Verständnis der Go-Sprache erlangen möchten, wird empfohlen, ihn zu lesen.
Kubernetes
Ein von Google entwickelter Container-Planungsdienst, der auf Docker basiert. Benutzer können Cloud-Container-Cluster über Kubernetes-Cluster verwalten.
etcd
Ein verteiltes, zuverlässiges KV-Speichersystem, das schnell in der Cloud konfiguriert werden kann.
beego
beego ist ein Python-ähnliches Tornado-Framework, das die RESTFul-Designidee übernimmt und ein extrem leichtes, hoch skalierbares und leistungsstarkes Webanwendungs-Framework ist, das in der Go-Sprache geschrieben ist.
martini
Ein Web-Framework zum schnellen Erstellen modularer Webanwendungen.
codis
Ausgezeichnete inländische verteilte Redis-Lösung.
delve
Der leistungsstarke Debugger der Go-Sprache ist in viele integrierte Umgebungen und Editoren integriert.
Facebook nutzt es auch. Aus diesem Grund haben sie auch eine Open-Source-Organisation facebookgo auf Github gegründet. Sie können sich die Open-Source-Projekte von Facebook ansehen, wie zum Beispiel das berühmte Grace, das reibungslos aktualisiert wird.
Tencent
Als großes inländisches Unternehmen wagt Tencent immer noch den Versuch, insbesondere im Bereich der Docker-Containerisierung. Einzelheiten finden Sie unter
http: // www.infoq.com/cn/articles/tencent-millions-scale-docker-application-practice
Baidu
Der derzeit bekannte Einsatz von Baidu erfolgt auf der Betriebs- und Wartungsseite und ist ein BFE-Projekt Betrieb und Wartung von Baidu, verantwortlich für den Zugriff auf den Front-End-Verkehr. Ihr Verantwortlicher hat es 2016 geteilt. Sie können sich dies hier ansehen: http://www.infoq.com/cn/presentations/application-of-golang-in-baidu-frontend
Das zweite ist das Nachrichtensystem von Baidu. Verantwortlich für die Entwicklung und Wartung der Serverseite des mobilen Messaging-Systems des Unternehmens.
JD
JD Cloud-Nachrichten-Push-System, Cloud-Speicher und JD Mall nutzen alle Go für die Entwicklung.
Xiaomi
Xiaomis Unterstützung für Golang ist nichts anderes als das Open-Source-Betriebs- und Wartungsüberwachungssystem http://open-falcon.com/.
Darüber hinaus nutzen Xiaomi Interactive Entertainment, Xiaomi Mall, Xiaomi Video, Xiaomi Ecological Chain und andere Teams Golang.
360
360 verwendet auch häufig das Open-Source-Protokollsuchsystem Poseidon, das auf Github gehostet wird.
Das Push-Team von 360 verwendet auch Golang auf der offiziellen Seite Blog.
Meituan
Meituan-Backend-Verkehrsunterstützungsprogramm. Anwendungsbereich: Unterstützen Sie den Backend-Verkehr der Hauptwebsite (Sortierung, Empfehlung, Suche usw.), stellen Sie Lastausgleich, Cache, Fehlertoleranz, bedingte Verteilung, statistische Betriebsindikatoren (QPS, Latenz) und andere Funktionen bereit.
Didi
Basis-Serviceplattform.
Kingsoft Weikan
Anwendungsbereich: Serviceschnittstelle, Hintergrundprozessdienst, Nachrichtensystem, Bildsystem
Sogou
Sogou-Push-System. Der Teil des Push-Systems, der zur Aufrechterhaltung der Verbindungen mit Clients verwendet wird.
. . . . .
Am Ende geschrieben
Ob eine Technologie weiterentwickelt werden kann, hängt natürlich von drei wesentlichen Punkten ab. (Die folgenden Ansichten stammen aus https://www.cnblogs.com/qwangxiao/p/8318894.html)
• Gibt es eine bessere Community? Die Ökosysteme von C, C++, Java, Python und JavaScript sind alle sehr umfangreich und beliebt. Vor allem Communities mit vielen beteiligten kommerziellen Organisationen erfreuen sich noch größerer Beliebtheit, etwa die Linux-Community.
• Gibt es einen Industriestandard? C, C++ und Java verfügen alle über Standardisierungsorganisationen. Insbesondere Java hat in Bezug auf die Architektur Standards auf Unternehmensebene wie J2EE entwickelt.
• Gibt es eine oder mehrere Killer-Apps? Unnötig zu erwähnen, dass die Killeranwendungen von C, C++ und Java, selbst für PHP, das noch keine gute Programmiersprache ist, Schlüsseltechnologien in LAMP sind, der ersten Killerlösung in der Linux-Ära, die daher ebenfalls entwickelt wurde. Die oben genannten drei Punkte sind sehr wichtig, um nur einen oder zwei davon zu berücksichtigen. Darüber hinaus sind einige Technologien, wie z. B. Java, für alle drei Punkte verantwortlich .
Natürlich gibt es neben den oben genannten drei wichtigen Punkten auch noch weitere Einflussfaktoren, wie zum Beispiel:
Die Zukunft der Go-Sprache ist also grenzenlos. Natürlich kann Go viele C-, C++- und Java-Projekte verschlingen. AllerdingsDie Hauptprojekte, die von der Go-Sprache verschluckt werden, sollten Projekte der mittleren Ebene sein, weder auf sehr niedriger Ebene noch auf der Geschäftsebene. Mit anderen Worten: Die Go-Sprache wird weder Low-Level-Projekte wie C und C++ noch High-Level-Projekte wie die Java-Business-Schicht verschlingen. Was die Go-Sprache verschlingen kann, müssen Projekte auf PaaS sein, wie etwa Middleware für das Zwischenspeichern von Nachrichten, Diensterkennung, Dienstagenten, Steuerungssysteme, Agenten, Protokollsammlung usw. Es gibt keine komplexen Geschäftsszenarien und sie kann keine speziellen unteren Schichten erreichen ( (z. B. Betriebssysteme) ist ein Softwareprojekt oder Tool, das eine Zwischenplattformschicht darstellt. C und C++ werden auf eine niedrigere Ebene verschoben, und Java wird auf eine höhere Geschäftsebene verschoben.
Okay, verwenden wir das obige Lineal, um Docker, die Killeranwendung der Go-Sprache, zu messen, und Sie werden feststellen, dass es im Grunde dasselbe ist.
Docker ist einfach zu nutzen.
Docker löst die Umweltprobleme bei Betrieb und Wartung sowie die Schwachstellen bei der Serviceplanung.
Hinter dem Docker-Ökosystem stehen große Unternehmen. Wie Google.
Docker produziert den Industriestandard OCI.
Die Community und das Ökosystem von Docker haben bereits die gleiche Dynamik erlebt wie Java und Linux.
【Verwandte Empfehlungen:Go-Video-Tutorial,Programmierunterricht】
Das obige ist der detaillierte Inhalt vonKann die Go-Sprache zum Programmieren verwendet werden?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!