جلسه مهم با Docker Swarm (CE) در Debian 9

معرفی

Docker Swarm سرورهای فردی شما را به مجموعه ای از رایانه ها تبدیل می کند. تسهیل مقیاس پذیری ، در دسترس بودن زیاد و توازن بار. Swarm Loading Balance یک استراتژی توازن بار بار رابط کاربری دور رابین را اجرا می کند ، و این ممکن است عملکرد صحیح برنامه (میراث) حالتدار را ایجاد کند که به نوعی جلسات چسبناک احتیاج دارد تا یک مجموعه پرمصرف در دسترس با چند نمونه امکان پذیر باشد. Docker Enterprise Edition از جلسه چسبنده Layer-7 پشتیبانی می کند ، اما در این راهنما روی نسخه رایگان (CE) داکر تمرکز خواهیم کرد. برای اجرای جلسات مهم ، از Traefik استفاده خواهیم کرد.

پیش نیازها

  • حداقل دو مورد تازه Debian 9 مستقر و به روز شده در زیر شبکه مشابه با شبکه های خصوصی فعال شده است
  • Docker CE در این موارد نصب شده است
  • نمونه ها باید بخشی از همان Swarm باشند و باید بتوانند از طریق شبکه خصوصی با یکدیگر ارتباط برقرار کنند
  • دانش قبلی درباره Docker و Docker Swarm
  • یک کاربر غیر ریشه با sudoحقوق (اختیاری است اما به شدت توصیه می شود که از کاربر root استفاده نکنید)

در این آموزش ما از دو نمونه Vultr با آدرس های IP خصوصی 192.168.0.100و 192.168.0.101. هر دوی آنها گره های مدیر Docker Swarm هستند (که برای تولید ایده آل نیست بلکه برای این آموزش کافی است).

من کی هستم

در این آموزش از jwilder/whoamiتصویر docker به عنوان یک برنامه نمایشی استفاده می شود. این ظرف ساده به تماس REST با نام ظرف پاسخ دهنده پاسخ خواهد داد و در صورت کار بودن جلسات چسبنده ، آن را بسیار آسان می کند. این تصویر بدیهی است که فقط برای اهداف نمایشی مورد استفاده قرار می گیرد و نیاز به جایگزین کردن تصویر برنامه شخصی شما دارد.

سرویس whoami به شرح زیر پیکربندی شده است:

sudo docker network create whoaminet -d overlay
sudo docker service create --name whoami-service --mode global --network whoaminet --publish "80:8000"  jwilder/whoami
sudo iptables -I INPUT 1 -p tcp --dport 80 -j ACCEPT

اگر متعاقباً curlاز نقطه پایانی whoami REST استفاده http://192.168.0.100/کنیم ، می توانیم توازن بالایی رابین-روبن Docker Swarm در محل کار ببینیم:

curl http://192.168.0.100
I'm a6a8c9294fc3
curl http://192.168.0.100
I'm ae9d1763b4ad
curl http://192.168.0.100
I'm a6a8c9294fc3
curl http://192.168.0.100
I'm ae9d1763b4ad
curl http://192.168.0.100
I'm a6a8c9294fc3

در مرورگرهای مدرن مانند Chrome یا Firefox از این آزمایش استفاده نمی شود ، زیرا آنها برای زنده نگه داشتن اتصالات طراحی شده اند ، و Docker Swarm load-balancer تنها بر روی هر اتصال جدید به ظرف دیگر تغییر خواهد کرد . اگر می خواهید این کار را با یک مرورگر انجام دهید ، باید حداقل 30 ثانیه منتظر بمانید تا اتصال دوباره بسته شود تا دوباره تجدید شود.

تنظیم Traefik

Traefik بومی از Docker Swarm پشتیبانی می کند ، می تواند ظروف را در پرواز تشخیص داده و ثبت نام کند یا ثبت نام کند و با برنامه شما از طریق شبکه پوشش داخلی ارتباط برقرار کند. Traefik قبل از شروع پردازش درخواست برای آن ، به برخی اطلاعات مربوط به برنامه شما نیاز دارد. این اطلاعات با افزودن برچسب ها به سرویس Swarm شما به Traefik ارائه می شود:

sudo docker service update --label-add "traefik.docker.network=whoaminet" --label-add "traefik.port=8000" --label-add "traefik.frontend.rule=PathPrefix:/" --label-add "traefik.backend.loadbalancer.stickiness=true" whoami-service

لیست زیر معنای هر برچسب را شرح می دهد:

  • traefik.docker.network : شبکه روکش Docker ، که از طریق آن Traefik با خدمات شما ارتباط برقرار خواهد کرد
  • traefik.port : درگاهی که سرویس شما در آن گوش می دهد (این درگاه داخلی است ، نه درگاه منتشر شده)
  • traefik.frontend.rule: PathPrefix:/ ریشه متن " /" را به این سرویس وصل می کند
  • traefik.backend.loadbalancer.stickiness : جلسات مهم را برای این سرویس فعال می کند

اکنون که whoami-serviceبا برچسب های مورد نیاز پیکربندی شده است ، می توانیم سرویس Traefik را به swarm اضافه کنیم:

sudo docker service create --name traefik -p8080:80 -p9090:8080 --mount type=bind,source=/var/run/docker.sock,destination=/var/run/docker.sock --mode=global --constraint 'node.role == manager' --network whoaminet traefik --docker --docker.swarmmode --docker.watch --web --loglevel=DEBUG

این دستور همانطور که در لیست زیر نشان داده شده است ، کارهای زیادی انجام می دهد:

  • --name traefik : نام سرویس جدید Docker ما Traefik است
  • -p8080:80: ما بندر Traefik را 80به صورت پورت منتشر می کنیم 8080زیرا 80این سرویس در حال حاضر توسط سرویس whoami ما استفاده می کند
  • -p9090:8080 : رابط وب شخصی Traefik را به صورت پورت منتشر می کنیم 9090
  • --mount ... : ما سوکت Docker را درون ظرف قرار می دهیم تا Traefik بتواند به زمان اجرا میزبان Docker دسترسی پیدا کند
  • --global : ما به دلایل در دسترس بودن زیاد ، ظروف Traefik را در هر گره مدیر می خواهیم
  • --constraint 'node.role == manager': ما فقط می خواهیم Traefik روی گره های مدیر اجرا شود زیرا گره های کارگر نمی توانند اطلاعات مورد نیاز را به Traefik ارائه دهند. به عنوان مثال ، docker service lsدر یک گره کارگر کار نمی کند ، بنابراین Traefik حتی قادر به کشف چه سرویس هایی نیست
  • --network whoaminet: Traefik را به همان شبکه وصل کنید whoami-service، در غیر این صورت نمی تواند به آن وصل شود. ما قبلاً به Traefik گفته بودیم تا از طریق این شبکه با traefik.docker.networkبرچسب به خدمات ما وصل شود
  • traefik : به docker بگویید که از جدیدترین تصویر docker Traefik برای این سرویس استفاده کند
  • --docker --docker.swarmmode --docker.watch --web --loglevel=DEBUG: آرگومان های خط فرمان به طور مستقیم به Traefik منتقل شد تا اجازه دهد در حالت swarm Docker اجرا شود. DEBUGدر اینجا اختیاری است ، اما در هنگام راه اندازی جالب است ، و برای این آموزش

تمام کارهایی که برای انجام کار باقی مانده باز کردن درگاه های لازم در دیواره آتش دبیان است:

sudo iptables -I INPUT 1 -p tcp --dport 8080 -j ACCEPT
sudo iptables -I INPUT 1 -p tcp --dport 9090 -j ACCEPT

چگونه کار می کند

به محض شروع Traefik ، می توانید در سیاهههای مربوط مشاهده کنید که Traefik دو whoamiظرف را کشف می کند . همچنین نام کوکی را که برای استفاده از جلسه چسبنده استفاده می کند ، تولید می کند:

time="2018-11-25T13:17:30Z" level=debug msg="Configuration received from provider docker: {\"backends\":{\"backend-whoami-service\":{\"servers\":{\"server-whoami-service-1-a179b2e38a607b1127e5537c2e614b05\":{\"url\":\"http://10.0.0.5:8000\",\"weight\":1},\"server-whoami-service-2-df8a622478a5a709fcb23c50e689b5b6\":{\"url\":\"http://10.0.0.4:8000\",\"weight\":1}},\"loadBalancer\":{\"method\":\"wrr\",\"stickiness\":{}}}},\"frontends\":{\"frontend-PathPrefix-0\":{\"entryPoints\":[\"http\"],\"backend\":\"backend-whoami-service\",\"routes\":{\"route-frontend-PathPrefix-0\":{\"rule\":\"PathPrefix:/\"}},\"passHostHeader\":true,\"priority\":0,\"basicAuth\":null}}}"
time="2018-11-25T13:17:30Z" level=debug msg="Wiring frontend frontend-PathPrefix-0 to entryPoint http"
time="2018-11-25T13:17:30Z" level=debug msg="Creating backend backend-whoami-service"
time="2018-11-25T13:17:30Z" level=debug msg="Adding TLSClientHeaders middleware for frontend frontend-PathPrefix-0"
time="2018-11-25T13:17:30Z" level=debug msg="Creating load-balancer wrr"
time="2018-11-25T13:17:30Z" level=debug msg="Sticky session with cookie _a49bc"
time="2018-11-25T13:17:30Z" level=debug msg="Creating server server-whoami-service-1-a179b2e38a607b1127e5537c2e614b05 at http://10.0.0.5:8000 with weight 1"
time="2018-11-25T13:17:30Z" level=debug msg="Creating server server-whoami-service-2-df8a622478a5a709fcb23c50e689b5b6 at http://10.0.0.4:8000 with weight 1"
time="2018-11-25T13:17:30Z" level=debug msg="Creating route route-frontend-PathPrefix-0 PathPrefix:/"
time="2018-11-25T13:17:30Z" level=info msg="Server configuration reloaded on :80"
time="2018-11-25T13:17:30Z" level=info msg="Server configuration reloaded on :8080"

اگر به http://192.168.0.100:8080آن توجه کنیم ، می بینیم که یک کوکی جدید ، _a49bcتنظیم شده است:

curl -v http://192.168.0.100:8080
* About to connect() to 192.168.0.100 port 8080 (#0)
*   Trying 192.168.0.100...
* Connected to 192.168.0.100 (192.168.0.100) port 8080 (#0)
> GET / HTTP/1.1
> User-Agent: curl/7.29.0
> Host: 192.168.0.100:8080
> Accept: */*
>
< HTTP/1.1 200 OK
< Content-Length: 17
< Content-Type: text/plain; charset=utf-8
< Date: Sun, 25 Nov 2018 13:18:40 GMT
< Set-Cookie: _a49bc=http://10.0.0.5:8000; Path=/
<
I'm a6a8c9294fc3
* Connection #0 to host 192.168.0.100 left intact

اگر در تماس های بعدی ، این کوکی را به Traefik ارسال کنیم ، همیشه به همان ظرف منتقل می شویم:

curl http://192.168.0.100:8080 --cookie "_a49bc=http://10.0.0.5:8000"
I'm a6a8c9294fc3
curl http://192.168.0.100:8080 --cookie "_a49bc=http://10.0.0.5:8000"
I'm a6a8c9294fc3
curl http://192.168.0.100:8080 --cookie "_a49bc=http://10.0.0.5:8000"
I'm a6a8c9294fc3
curl http://192.168.0.100:8080 --cookie "_a49bc=http://10.0.0.5:8000"
I'm a6a8c9294fc3

این کوکی چیزی جز آدرس IP داخلی ظرفی که Traefik باید برای درخواست ارسال کند ، ندارد. اگر به مقدار کوکی تغییر دهید http://10.0.0.4:8000، در نتیجه درخواست به طور مستقیم به ظرف دیگر ارسال می شود. اگر کوکی هرگز به Traefik ارسال نشد ، جلسه چسبنده کار نخواهد کرد و درخواستها بین ظروف برنامه و ظروف Traefik متعادل خواهد شد.

این تنها کاری است که برای راه اندازی Layer 7 Sticky Sessions در Docker CE در Debian 9 لازم است.



Leave a Comment

Kubernetes With Kubeadm را در CentOS 7 مستقر کنید

Kubernetes With Kubeadm را در CentOS 7 مستقر کنید

بررسی اجمالی این مقاله به شما کمک می کند تا در هر زمان خوشه ای از Kubernetes را جمع کنید و با kubeadm در حال اجرا باشید. در این راهنما از دو سرور استفاده می شود

Docker CE را در اوبونتو 18.04 نصب کنید

Docker CE را در اوبونتو 18.04 نصب کنید

مقدمه Docker برنامه ای است که به ما امکان می دهد برنامه هایی را که به صورت ظروف اجرا می شوند مستقر کنیم. این متن با زبان محبوب برنامه نویسی Go نوشته شده است

نصب Docker در CentOS 7

نصب Docker در CentOS 7

با استفاده از یک سیستم متفاوت؟ Docker برنامه ای است که امکان استقرار نرم افزار در ظروف مجازی را فراهم می آورد. در برنامه نویسی Go نوشته شده است

Rancher را در اوبونتو 16.04 نصب کنید

Rancher را در اوبونتو 16.04 نصب کنید

با استفاده از یک سیستم متفاوت؟ مقدمه Rancher یک بستر منبع باز برای اجرای ظروف و ساخت سرویس کانتینر خصوصی است. رانچر پایه است

با استفاده از Docker-compose یک برنامه PHP مستقر کنید

با استفاده از Docker-compose یک برنامه PHP مستقر کنید

برنامه های PHP معمولاً توسط یک سرور ، یک سیستم پایگاه داده رابطه و خود مفسر زبان تشکیل می شوند. در این آموزش leveragin خواهیم بود

نصب docker-compose در CoreOS

نصب docker-compose در CoreOS

در این مقاله نحوه نصب docker-compose در CoreOS توضیح داده شده است. در CoreOS ، پوشه / usr / تغییر ناپذیر است بنابراین مسیر استاندارد / usr / local / bin در دسترس نیست

در CoreOS ، رجیستری خود را تنظیم کنید

در CoreOS ، رجیستری خود را تنظیم کنید

همه ما Docker را می شناسیم و دوست داریم ، سکویی برای ایجاد ، مدیریت و توزیع ظروف برنامه در دستگاه های مختلف. شرکت Docker یک سرویس t ارائه می دهد

Rancher را روی CentOS 7 نصب کنید

Rancher را روی CentOS 7 نصب کنید

با استفاده از یک سیستم متفاوت؟ مقدمه Rancher یک بستر منبع باز برای اجرای ظروف و ساخت سرویس کانتینر خصوصی است. رانچر پایه است

Sentry Sentry را از طریق Docker در اوبونتو 16.04 تنظیم کنید

Sentry Sentry را از طریق Docker در اوبونتو 16.04 تنظیم کنید

با استفاده از یک سیستم متفاوت؟ مقدمه Sentry یک راه حل منبع باز برای ردیابی خطا است. Sentry استثنائات و سایر پیام های مفید را از این طریق دنبال می کند

ایجاد یک Darmer Swarm در Alpine Linux 3.9.0

ایجاد یک Darmer Swarm در Alpine Linux 3.9.0

مقدمه این راهنما نحوه ایجاد و پیکربندی ازدحام Docker را با استفاده از چندین سرور Alpine Linux 3.9.0 و Portainer به شما نشان می دهد. لطفا آگاه باشید

جلسه Sticky With Docker Swarm (CE) در CentOS 7

جلسه Sticky With Docker Swarm (CE) در CentOS 7

با استفاده از یک سیستم متفاوت؟ مقدمه Docker Swarm سرورهای فردی شما را به مجموعه ای از رایانه ها تبدیل می کند و باعث می شود مقیاس پذیری و در دسترس بودن بالا را تسهیل کند

دو ابزار مدیریت گرافیکی Docker: DockerUI و Shipyard

دو ابزار مدیریت گرافیکی Docker: DockerUI و Shipyard

با کمک برنامه Vultr Docker ، به راحتی می توانید Docker را به عنوان نمونه سرور Vultr خود مستقر کنید. در ضمن ، می توانید وظیفه مدیریت داکر را تسهیل کنید

نحوه نصب Harbour در CentOS 7

نحوه نصب Harbour در CentOS 7

Harbour یک سرور رجیستری کلاس سازمانی منبع باز است که تصاویر Docker را ذخیره و توزیع می کند. بندرگاه منبع باز Docker Distribution b را گسترش می دهد

سرور Rancher را روی RancherOS نصب کنید

سرور Rancher را روی RancherOS نصب کنید

بررسی اجمالی RancherOS یک سیستم عامل فوق العاده سبک (فقط حدود 60 مگابایت) است که برای اجرای سرویس های سیستم ، یک Demoner سیستم Docker به عنوان PID 0 را اجرا می کند.

با خیال راحت ظروف LXC را در Ubuntu 14.04 مستقر و مدیریت کنید

با خیال راحت ظروف LXC را در Ubuntu 14.04 مستقر و مدیریت کنید

ظروف LXC (ظروف لینوکس) یک ویژگی سیستم عامل در لینوکس است که می تواند برای اجرای چندین سیستم جدا شده لینوکس روی یک هاست واحد مورد استفاده قرار گیرد. اینها

شروع کار با Kubernetes در CentOS 7

شروع کار با Kubernetes در CentOS 7

Kubernetes یک سیستم عامل منبع باز است که توسط Google برای مدیریت برنامه های کانتینر شده در سرتاسر گروههای سرور ساخته شده است. این بنا بر روی یک دهه ساخته می شود و

نحوه استفاده از داکر: ایجاد اولین کانتینر داکر

نحوه استفاده از داکر: ایجاد اولین کانتینر داکر

در این آموزش اصول اولیه کار با داکر توضیح داده شده است. فرض می کنم شما قبلاً داکر نصب کرده اید. مراحل این آموزش روی آن کار خواهد کرد

بار را با Docker بارگذاری کنید

بار را با Docker بارگذاری کنید

هنگام اجرای یک برنامه وب ، شما معمولاً می خواهید بدون استفاده از نرم افزار خود برای استفاده از multithreading o از منابع خود استفاده کنید.

با SQL Server 2017 (MS-SQL) در CentOS 7 With Docker شروع کنید

با SQL Server 2017 (MS-SQL) در CentOS 7 With Docker شروع کنید

پیش نیاز موتور داکر 1.8+. حداقل 4 گیگابایت فضای دیسک. حداقل 4 گیگابایت رم. مرحله 1. نصب Docker به منظور نصب SQL-Server ، Docker mus

نحوه نصب بستر سبد خرید LiteCart در اوبونتو 16.04

نحوه نصب بستر سبد خرید LiteCart در اوبونتو 16.04

LiteCart یک بستر سبد خرید آزاد و منبع باز است که به زبان های PHP ، jQuery و HTML 5 نوشته شده است. این نرم افزار ساده ، سبک و با کاربرد آسان است.

نحوه نصب Anchor CMS بر روی یک VPS Fedora 26 LAMP

نحوه نصب Anchor CMS بر روی یک VPS Fedora 26 LAMP

با استفاده از یک سیستم متفاوت؟ Anchor CMS یک سیستم مدیریت محتوا (CMS) بسیار ساده و بسیار سبک ، بسیار آزاد و آزاد است.

اشتراک NFS را در Debian تنظیم کنید

اشتراک NFS را در Debian تنظیم کنید

NFS یک سیستم فایل مبتنی بر شبکه است که به رایانه ها اجازه می دهد تا از طریق شبکه رایانه ای به فایلها دسترسی پیدا کنند. این راهنما توضیح می دهد که چگونه می توانید پوشه ها را روی NF قرار دهید

نحوه بروزرسانی CentOS 7 ، Ubuntu 16.04 و Debian 8

نحوه بروزرسانی CentOS 7 ، Ubuntu 16.04 و Debian 8

هنگام راه اندازی سرور جدید لینوکس ، به روزرسانی سیستم های هسته و سایر بسته ها تا آخرین نسخه پایدار یک روش توصیه شده است. در این مقاله

نحوه نصب Matomo Analytics در Fedora 28

نحوه نصب Matomo Analytics در Fedora 28

با استفاده از یک سیستم متفاوت؟ Matomo (سابقا پیویک) یک بستر تحلیلی منبع باز است ، یک جایگزین باز برای Google Analytics. منبع Matomo میزبان o

یک سرور TeamTalk را در لینوکس تنظیم کنید

یک سرور TeamTalk را در لینوکس تنظیم کنید

TeamTalk یک سیستم کنفرانس است که به کاربران امکان می دهد مکالمات صوتی / تصویری با کیفیت بالا ، چت متنی ، انتقال فایل ها و صفحه های به اشتراک بگذارند. من

با استفاده از کلید SSH خود برای ورود به کاربران غیر ریشه استفاده کنید

با استفاده از کلید SSH خود برای ورود به کاربران غیر ریشه استفاده کنید

Vultr یک ویژگی را فراهم می کند که به شما امکان می دهد با ایجاد یک نمونه جدید ، کلیدهای SSH را از قبل نصب کنید. این اجازه می دهد تا به کاربر root دسترسی داشته باشید ، با این حال ، th

نحوه نصب انجمن NodeBB در FreeBSD 12

نحوه نصب انجمن NodeBB در FreeBSD 12

با استفاده از یک سیستم متفاوت؟ NodeBB یک نرم افزار انجمن مبتنی بر Node.js است. از سوکت های وب برای تعامل فوری و اعلامیه های زمان واقعی استفاده می کند. NodeB

نصب و راه اندازی ZNC در اوبونتو

نصب و راه اندازی ZNC در اوبونتو

ZNC یک پیشرانه پیشرفته شبکه IRC است که تمام وقت بهم متصل می شود تا مشتری IRC بتواند بدون از دست دادن جلسه گپ قطع یا وصل شود.

نحوه نصب Ranger Terminal File Manager در لینوکس

نحوه نصب Ranger Terminal File Manager در لینوکس

رنجر یک مدیر فایل مبتنی بر خط فرمان است که دارای کلیدهای اتصال VI است. این برنامه یک رابط لعنتی مینیمالیستی و زیبا با نمای سلسله مراتب فهرست ارائه می دهد