cari
Rumahpembangunan bahagian belakangGolangMelaksanakan sistem teragih menggunakan rangka kerja Web Golang rangka kerja Buffalo

Sistem teragih ialah sistem yang terdiri daripada berbilang komputer bebas dengan data dan tugas dikongsi sesama mereka. Komputer ini berkomunikasi antara satu sama lain melalui rangkaian untuk menyelesaikan tugas bersama-sama. Dalam sistem ini, setiap komputer adalah bebas dan mereka boleh menggunakan sistem pengendalian dan bahasa pengaturcaraan yang berbeza. Untuk membolehkan komputer ini berfungsi bersama, kita memerlukan rangka kerja untuk menyelaraskan operasinya. Dalam artikel ini, kami akan memperkenalkan cara menggunakan rangka kerja Buffalo Golang untuk melaksanakan sistem teragih.

Golang ialah bahasa pengaturcaraan yang cekap, dan menggunakan Golang dalam sistem teragih adalah lebih baik daripada bahasa lain. Oleh itu, kami memilih Golang sebagai bahasa pembangunan kami. Rangka kerja Buffalo ialah rangka kerja web Golang yang popular yang menawarkan kelebihan pembangunan pesat dan pembangunan kolaboratif. Dalam rangka kerja ini, kami boleh menggunakan perkhidmatan automasinya untuk mencipta dan mengurus aplikasi.

Apabila mencipta sistem teragih, kita perlu mempertimbangkan faktor berikut:

  1. Berkomunikasi antara satu sama lain: Komputer dalam sistem teragih perlu berkomunikasi antara satu sama lain untuk berfungsi bersama. Untuk mencapai ini, kami boleh menggunakan RESTful API atau protokol gRPC.
  2. Penyegerakan data: Memandangkan komputer dalam sistem teragih adalah bebas, ia mungkin mempunyai data yang berbeza. Oleh itu, kita perlu mempertimbangkan cara menyegerakkan data ini.
  3. Pengimbangan Beban: Untuk menjadikan sistem teragih lebih cekap, kita perlu memperuntukkan tugas kepada komputer dengan sumber pengkomputeran ganti.

Sekarang mari kita lihat cara menggunakan rangka kerja Buffalo untuk melaksanakan fungsi ini.

Buat aplikasi Buffalo

Kita perlu membuat aplikasi Buffalo pada pelayan terlebih dahulu. Kita boleh menggunakan Buffalo CLI untuk menyelesaikan tugas ini. Pasang Buffalo CLI dan buat aplikasi Buffalo baharu melalui baris arahan berikut:

$ go get -u -v github.com/gobuffalo/buffalo/cli/v2
$ buffalo new appname

Buffalo akan menjana struktur aplikasi asas. Kita boleh menggunakan arahan berikut untuk memulakan pelayan:

$ buffalo dev

Arahan ini akan memulakan pelayan web, dan kemudian kita boleh melawati http://127.0.0.1:3000 dalam penyemak imbas untuk melihat aplikasi.

Buat API RESTful

Seterusnya, kita perlu mencipta API RESTful untuk komputer dalam sistem teragih untuk berkomunikasi antara satu sama lain. Kami boleh menggunakan perkhidmatan automasi dalam rangka kerja Buffalo untuk menyelesaikan tugas ini.

Pertama, kita perlu mencipta pengawal yang mengendalikan permintaan API. Kita boleh menggunakan arahan berikut untuk mencipta pengawal:

$ buffalo generate resource user name email

Arahan ini akan menjana pengawal bernama "pengguna", dan pengawal mengandungi dua parameter: "nama" dan "e-mel". Kita boleh menambah logik pada pengawal untuk membolehkannya bertindak balas kepada pelbagai jenis permintaan.

Untuk komputer dalam sistem teragih untuk berkomunikasi antara satu sama lain, kita perlu membuat permintaan POST dan GET. Kami boleh menambah kod berikut dalam pengawal untuk mengendalikan permintaan ini:

func (v *UsersResource) Create(c buffalo.Context) error {
    user := &models.User{}
    if err := c.Bind(user); err != nil {
        return err
    }

    // Add validation logic here!

    tx := c.Value("tx").(*pop.Connection)
    if err := tx.Create(user); err != nil {
        return err
    }

    return c.Render(201, r.JSON(user))
}

func (v *UsersResource) List(c buffalo.Context) error {
    users := &models.Users{}
    tx := c.Value("tx").(*pop.Connection)
    if err := tx.All(users); err != nil {
        return err
    }

    return c.Render(200, r.JSON(users))
}

Kod ini akan mengendalikan permintaan POST dan GET dan mengembalikan data respons berformat JSON kepada klien.

Menggunakan protokol gRPC

Selain API RESTful, kami juga boleh menggunakan protokol gRPC untuk melaksanakan komunikasi antara komputer. Rangka kerja Buffalo menyokong protokol gRPC dan kami boleh memasang pemalam Buffalo-gRPC menggunakan arahan berikut:

$ buffalo plugins install buffalo-grpc

Seterusnya, kami perlu menjana kod perkhidmatan gRPC untuk aplikasi kami. Kita boleh menggunakan arahan berikut untuk menjana kod:

$ buffalo generate grpc user

Arahan ini akan menjana perkhidmatan gRPC bernama "pengguna".

Dalam kod pelayan, kami perlu melaksanakan kaedah yang ditakrifkan dalam perkhidmatan gRPC. Kami boleh melaksanakan kaedah ini dalam kod berikut:

type UserServer struct{}

func (s *UserServer) GetUser(ctx context.Context, req *user.GetUserRequest) (*user.GetUserResponse, error) {
    // Insert user retrieval logic here
}

func (s *UserServer) CreateUser(ctx context.Context, req *user.CreateUserRequest) (*user.User, error) {
    // Insert user creation logic here
}

Dalam kod pelanggan, kami boleh menggunakan kod berikut untuk memanggil perkhidmatan gRPC:

conn, err := grpc.Dial("localhost:50051", grpc.WithInsecure())
if err != nil {
    log.Fatalf("failed to connect: %s", err)
}
defer conn.Close()

client := user.NewUserClient(conn)
res, err := client.GetUser(context.Background(), &user.GetUserRequest{Id: "123"})
if err != nil {
    log.Fatalf("failed to get user: %s", err)
}

log.Printf("user: %v", res)

Menggunakan Redis sebagai cache dalam sistem teragih

Dalam sistem teragih, untuk mempercepatkan capaian data, kami biasanya menggunakan cache. Redis ialah alat caching popular yang menyokong sistem teragih dan membolehkan kami menyimpan dan mendapatkan data dengan cepat. Kita boleh memasang Redis menggunakan arahan berikut:

$ brew install redis

Seterusnya, kita boleh menggunakan Redis sebagai cache dalam aplikasi kita. Kita boleh menggunakan arahan berikut untuk memasang pemalam Redis:

$ buffalo plugins install buffalo-redis

Seterusnya, kita boleh menggunakan kod berikut dalam aplikasi untuk mengkonfigurasi Redis:

var (
    RedisClient *redis.Client
)

func init() {
    RedisClient = redis.NewClient(&redis.Options{
        Addr: "localhost:6379",
    })
}

func main() {
    app := buffalo.New(buffalo.Options{})
    app.Use(midware.Redis(RedisClient))
    // ...
}

Seterusnya, kita boleh gunakan dalam pengawal The kod berikut digunakan untuk menyimpan data ke dalam Redis:

func (v *UsersResource) Create(c buffalo.Context) error {
    user := &models.User{}
    if err := c.Bind(user); err != nil {
        return err
    }

    // Add validation logic here!

    if err := RedisClient.Set("user_"+user.ID.String(), user, 0).Err(); err != nil {
        return err
    }

    // Add logic to store user in database

    return c.Render(201, r.JSON(user))
}

Dalam contoh ini, kami menyimpan pengguna ke dalam cache Redis dan menggunakan ID pengguna sebagai kunci. Ini akan membolehkan kami mendapatkan semula data pengguna dengan cepat kemudian.

Mencapai pengimbangan beban

Akhir sekali, kita perlu melaksanakan fungsi pengimbangan beban. Dalam sistem teragih, kami mahu dapat memperuntukkan tugas pengkomputeran kepada komputer dengan sumber pengkomputeran ganti. Kami boleh menggunakan pelayan proksi terbalik untuk mencapai tugas ini.

Nginx ialah pelayan proksi terbalik yang popular yang menyokong pengimbangan beban dan penyulitan HTTPS. Kami boleh memasang Nginx pada pelayan dan menggunakan fail konfigurasi berikut untuk mencapai pengimbangan beban:

http {
    upstream app_servers {
        server 127.0.0.1:3001;
        server 127.0.0.1:3002;
        server 127.0.0.1:3003;
    }

    server {
        listen 80;
        server_name example.com;

        location / {
            proxy_pass http://app_servers;
        }
    }
}

Fail konfigurasi ini mengedarkan permintaan kepada tiga pelayan berbeza dan menggunakan algoritma round-robin untuk menentukan tempat untuk mengedarkan pelayan permintaan.

Kesimpulan

Dengan menggunakan rangka kerja Buffalo, kami boleh melaksanakan sistem teragih dengan cepat dan menyokong berbilang protokol komunikasi, termasuk RESTful API dan gRPC. Kami juga boleh menggunakan Redis untuk mempercepatkan akses data dan mencapai pengimbangan beban dengan menggunakan pelayan proksi terbalik. Melalui kaedah ini, kami boleh menjadikan sistem teragih lebih cekap dan mencapai kelajuan pengkomputeran yang lebih pantas.

Atas ialah kandungan terperinci Melaksanakan sistem teragih menggunakan rangka kerja Web Golang rangka kerja Buffalo. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
go语言有没有缩进go语言有没有缩进Dec 01, 2022 pm 06:54 PM

go语言有缩进。在go语言中,缩进直接使用gofmt工具格式化即可(gofmt使用tab进行缩进);gofmt工具会以标准样式的缩进和垂直对齐方式对源代码进行格式化,甚至必要情况下注释也会重新格式化。

聊聊Golang中的几种常用基本数据类型聊聊Golang中的几种常用基本数据类型Jun 30, 2022 am 11:34 AM

本篇文章带大家了解一下golang 的几种常用的基本数据类型,如整型,浮点型,字符,字符串,布尔型等,并介绍了一些常用的类型转换操作。

go语言为什么叫gogo语言为什么叫goNov 28, 2022 pm 06:19 PM

go语言叫go的原因:想表达这门语言的运行速度、开发速度、学习速度(develop)都像gopher一样快。gopher是一种生活在加拿大的小动物,go的吉祥物就是这个小动物,它的中文名叫做囊地鼠,它们最大的特点就是挖洞速度特别快,当然可能不止是挖洞啦。

一文详解Go中的并发【20 张动图演示】一文详解Go中的并发【20 张动图演示】Sep 08, 2022 am 10:48 AM

Go语言中各种并发模式看起来是怎样的?下面本篇文章就通过20 张动图为你演示 Go 并发,希望对大家有所帮助!

tidb是go语言么tidb是go语言么Dec 02, 2022 pm 06:24 PM

是,TiDB采用go语言编写。TiDB是一个分布式NewSQL数据库;它支持水平弹性扩展、ACID事务、标准SQL、MySQL语法和MySQL协议,具有数据强一致的高可用特性。TiDB架构中的PD储存了集群的元信息,如key在哪个TiKV节点;PD还负责集群的负载均衡以及数据分片等。PD通过内嵌etcd来支持数据分布和容错;PD采用go语言编写。

聊聊Golang自带的HttpClient超时机制聊聊Golang自带的HttpClient超时机制Nov 18, 2022 pm 08:25 PM

​在写 Go 的过程中经常对比这两种语言的特性,踩了不少坑,也发现了不少有意思的地方,下面本篇就来聊聊 Go 自带的 HttpClient 的超时机制,希望对大家有所帮助。

go语言是否需要编译go语言是否需要编译Dec 01, 2022 pm 07:06 PM

go语言需要编译。Go语言是编译型的静态语言,是一门需要编译才能运行的编程语言,也就说Go语言程序在运行之前需要通过编译器生成二进制机器码(二进制的可执行文件),随后二进制文件才能在目标机器上运行。

golang map怎么删除元素golang map怎么删除元素Dec 08, 2022 pm 06:26 PM

删除map元素的两种方法:1、使用delete()函数从map中删除指定键值对,语法“delete(map, 键名)”;2、重新创建一个新的map对象,可以清空map中的所有元素,语法“var mapname map[keytype]valuetype”。

See all articles

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Alat panas

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SecLists

SecLists

SecLists ialah rakan penguji keselamatan muktamad. Ia ialah koleksi pelbagai jenis senarai yang kerap digunakan semasa penilaian keselamatan, semuanya di satu tempat. SecLists membantu menjadikan ujian keselamatan lebih cekap dan produktif dengan menyediakan semua senarai yang mungkin diperlukan oleh penguji keselamatan dengan mudah. Jenis senarai termasuk nama pengguna, kata laluan, URL, muatan kabur, corak data sensitif, cangkerang web dan banyak lagi. Penguji hanya boleh menarik repositori ini ke mesin ujian baharu dan dia akan mempunyai akses kepada setiap jenis senarai yang dia perlukan.

MantisBT

MantisBT

Mantis ialah alat pengesan kecacatan berasaskan web yang mudah digunakan yang direka untuk membantu dalam pengesanan kecacatan produk. Ia memerlukan PHP, MySQL dan pelayan web. Lihat perkhidmatan demo dan pengehosan kami.

mPDF

mPDF

mPDF ialah perpustakaan PHP yang boleh menjana fail PDF daripada HTML yang dikodkan UTF-8. Pengarang asal, Ian Back, menulis mPDF untuk mengeluarkan fail PDF "dengan cepat" dari tapak webnya dan mengendalikan bahasa yang berbeza. Ia lebih perlahan dan menghasilkan fail yang lebih besar apabila menggunakan fon Unicode daripada skrip asal seperti HTML2FPDF, tetapi menyokong gaya CSS dsb. dan mempunyai banyak peningkatan. Menyokong hampir semua bahasa, termasuk RTL (Arab dan Ibrani) dan CJK (Cina, Jepun dan Korea). Menyokong elemen peringkat blok bersarang (seperti P, DIV),

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

Persekitaran pembangunan bersepadu PHP yang berkuasa