استفاده از سرور VPN سازگار AnyConnect با تأیید گواهینامه در CentOS 7

AnyConnect یک راه حل دسترسی از راه دور است که توسط سیسکو ساخته شده است. به دلیل قابلیت حمل و پایداری و خصوصاً قابلیت DTLS که دارد ، AnyConnect در بسیاری از شرکت ها مورد استفاده قرار می گیرد. ما می خواهیم از نسخه منبع باز استفاده کنیم ocserv، که با پروتکل سازگار است.

ما همچنین قصد داریم تأییدیه گواهینامه را مستقر کنیم. سرور با بررسی اینکه گواهی مشتری توسط CA تنظیم شده صادر شده است ، مشتری را شناسایی می کند. این امر پیکربندی مشتری را بسیار ساده تر می کند زیرا ما فقط نیاز به وارد کردن گواهینامه در مشتری (بیشتر اوقات پرونده pkcs12 ( .pfxیا .p12)) داریم و هیچ رمز عبور لازم نیست. این همچنین از امنیت بیشتری برخوردار است زیرا هیچ گذرواژه ای در اینترنت تردد نمی کند.

بیا شروع کنیم.

پیش نیازها

  • یک سرور CentOS 7 تازه ایجاد شده با IPv6 فعال شده است
  • یک رایانه در حال کار (می تواند خود سرور باشد ؛ هرچند مستهلک شود (به تصویر زیر مراجعه کنید)) به یادداشت شماره 1 مراجعه کنید
  • برخی از مشتریانی که نرم افزار سرویس گیرنده AnyConnect (یا OpenConnect) نصب شده اند ، به یادداشت 2 مراجعه کنند

یادداشت:

  1. اگرچه انجام همه کارها روی سرور امکان پذیر است (و نه راحت) ، فرایند استقرار شامل تولید کلیدهای خصوصی است که برای امضاء استفاده می شود و به دلیل نگرانی های امنیتی ، این روند باید در رایانه شخصی شما انجام شود.

  2. به دلیل مشکلات صدور مجوز ، پیوندهایی برای بارگیری نرم افزار مشتری ارائه نمی دهم. اما پیدا کردن آنها برای مشتری شما بسیار آسان است. AnyConnect به ترتیب در فروشگاه های برنامه در سیستم عامل های اصلی تلفن همراه (iOS ، Android ، BlackBerry OS (v10 یا بالاتر) ، UWP) است و یک جستجوی ساده آنها را به سمت شما می آورد. برای سیستم عامل های رایانه شخصی ، برخی از Googling نرم افزار مناسبی را به شما معرفی می کنند.

نصب نرم افزار سمت سرور

ماشین های Vultr CentOS 7 با مخزن EPEL پیکربندی شده اند. ما فقط ocservبا نصب می کنیم yum:

yum update
yum install ocserv

برای کار کردن به گواهی سرور نیاز داریم. اگر نام دامنه دارید ، Letry Encrypt ساده ترین گزینه خواهد بود.

yum install certbot
certbot certonly

"چرخش سرور وب موقتی" را برای تأیید اعتبار با ACME CA انتخاب کنید. اگر دامنه ندارید ، یک گواهی خود امضا شده بعداً صادر می شود.

تولید و پیکربندی گواهی

PKI سنتی استفاده از آن بسیار ناخوشایند است ، بنابراین ما می توانیم easyrsaاز پروژه OpenVPN استفاده کنیم. git را روی دستگاه کار خود نصب کنید و مخزن را کلون کنید:

git clone https://github.com/OpenVPN/easy-rsa
cd easy-rsa/easyrsa3

ما CA را ساخته و گواهینامه هایی صادر می کنیم. موارد زیر را انجام دهید و عبارت عبور PEM را که در جایی تنظیم کرده اید بنویسید:

./easyrsa init-pki
./easyrsa build-ca

در pki/private/ca.keyجایی ایمن باشید. نشتی باعث می شود کل زیرساخت های شما بی فایده شود.

اگر تصمیم به استفاده از گواهی سرور خود امضا کرده اید ، موارد زیر را انجام دهید:

./easyrsa gen-req server

و آدرس IP سرور خود را به عنوان نام مشترک وارد کنید.

./easyrsa sign-req server server

با این کار یک گواهی برای سرور امضا می شود. انتقال pki/issued/server.crtو pki/ca.crtبه /etc/ssl/certsو pki/private/server.keyبه /etc/ssl/privateروی سرور خود.

بعد گواهینامه های مشتری ایجاد خواهیم کرد. موارد زیر را انجام دهید:

./easyrsa gen-req client_01
./easyrsa sign-req client client_01

نام مشتری را انتخاب کنید و آن را در قسمت نام مشترک پر کنید. به یاد داشته باشید کلمه عبور!

در مرحله بعد می خواهیم گواهی را در قالب pkcs12 برای استفاده در سیستم عامل های تلفن همراه صادر کنیم. انجام دادن:

./easyrsa export-p12 client_01

رمز ورود صادراتی را انتخاب کنید که هنگام وارد کردن گواهی بر روی تلفن از شما خواسته می شود وارد کنید. pki/private/client_01.p12به تلفن خود انتقال داده و آن را وارد کنید.

پیکربندی سرور

اطلاعات گواهی را پر می کنیم.

vim /etc/ocserv/ocserv.conf

تعیین محل server-certبخش و پر کردن موارد زیر است:

# If you use Let's Encrypt
server-cert = /etc/letsencrypt/live/example.com/fullchain.pem
server-key = /etc/letsencrypt/live/example.com/privkey.pem

# If you use self-signed server certificate 
server-cert = /etc/ssl/certs/server.crt
server-key = /etc/ssl/private/server.key

ca-cert = /etc/ssl/certs/ca.crt

توجه داشته باشید که اگر از یک گواهی خود امضا شده استفاده می کنید ، ابتدا به یاد داشته باشید که عبارت عبور را از این طریق حذف کنید openssl rsa -in server.key -out server-new.keyتا ocservبتوانید از کلید خصوصی استفاده کنید.

یافتن authبخش. فعال کردن این خط:

auth = "certificate"

و تمام authسطرهای دیگر را اظهار نظر کنید

لغو پاسخ این خط:

cert-user-oid = 2.5.4.3

تعیین محل ipv6-networkو پر کردن بلوک از IPv6 سرور شما. این بلوکی است که سرور از آن اجاره نامه می دهد.

ipv6-network = 2001:0db8:0123:4567::/64
ipv6-subnet-prefix = 124 

سرورهای DNS را تنظیم کنید.

dns = 8.8.8.8
dns = 8.8.4.4

سازگاری با مشتریان سیسکو را فعال کنید.

cisco-client-compat = true

پورت شما را در مجموعه باز tcp-portو udp-portو فعال کردن لباس مبدل در امدن برای هر دو IPv4 و IPv6 در firewalld.

سرور را شروع کنید.

systemctl enable ocserv
systemctl start ocserv

زمان تست!

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

journalctl -fu ocserv

همچنین ، اگر نرم افزار مشتری شما از ipv6 پشتیبانی کند ، حتی اگر شبکه مشتری شما آدرس شما را ارائه ندهد ، IPv6 باید در سمت مشتری کار کند. برای تست به این سایت بروید .

همه مجموعه از سرور جدید VPN سازگار با AnyConnect خود لذت ببرید!



Leave a Comment

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

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

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

تنظیم RethinkDB Cluster On CentOS 7

تنظیم RethinkDB Cluster On CentOS 7

مقدمه RethinkDB یک پایگاه داده NoSQL است که داده ها را به عنوان اسناد JSON ذخیره می کند. این یک زبان پرس و جو بسیار بصری است و از ویژگی های آن معمولا در دسترس است

نحوه نصب نسخه باز Vtiger CRM در CentOS 7

نحوه نصب نسخه باز Vtiger CRM در CentOS 7

Vtiger CRM یک نرم افزار محبوب مدیریت ارتباط با مشتری است که می تواند به بنگاهها در رشد فروش ، ارائه خدمات به مشتری و افزایش سود کمک کند. من

نحوه نصب کاناپه CMS 2.0 بر روی یک VPS CentOS 7 LAMP

نحوه نصب کاناپه CMS 2.0 بر روی یک VPS CentOS 7 LAMP

با استفاده از یک سیستم متفاوت؟ Couch CMS یک سیستم مدیریت محتوای منبع ساده و انعطاف پذیر ، آزاد و منبع باز (CMS) است که به طراحان وب اجازه می دهد تا طراحی کنند.

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

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

با استفاده از یک سیستم متفاوت؟ SonarQube یک ابزار منبع باز برای توسعه سیستم با کیفیت است. در جاوا نوشته شده است و چندین پایگاه داده را پشتیبانی می کند. فراهم می کند

نصب Netdata در CentOS 7

نصب Netdata در CentOS 7

با استفاده از یک سیستم متفاوت؟ Netdata یک ستاره در حال افزایش در زمینه نظارت بر معیارهای سیستم در زمان واقعی است. در مقایسه با سایر ابزارهای مشابه ، Netdata:

نحوه فعال سازی پشتیبانی HTTP / 2 در DirectAdmin (CentOS)

نحوه فعال سازی پشتیبانی HTTP / 2 در DirectAdmin (CentOS)

HTTP / 2 جدیدترین نسخه پروتکل HTTP است که از SPDY مستقر است. توسعه آن توسط Google آغاز شده است و HTTP / 2 تا حد زیادی بر اساس پایگاه کد است

نحوه نصب سرور Starbound در CentOS 7

نحوه نصب سرور Starbound در CentOS 7

با استفاده از یک سیستم متفاوت؟ در این آموزش ، Ill در مورد نحوه راه اندازی یک سرور Starbound در CentOS 7 توضیح می دهد. پیش نیازها: شما باید این بازی را روی خود داشته باشید

یک سرور چند نفره SA-MP San Andreas را در CentOS 6 تنظیم کنید

یک سرور چند نفره SA-MP San Andreas را در CentOS 6 تنظیم کنید

به یکی دیگر از آموزش های Vultr خوش آمدید. در اینجا ، نحوه نصب و اجرای سرور SAMP را یاد خواهید گرفت. این راهنما برای CentOS 6 نوشته شده است. پیش نیازهای مورد نیاز شما

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

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

با استفاده از یک سیستم متفاوت؟ Elgg یک موتور شبکه ای منبع باز است که امکان ایجاد محیط های اجتماعی از جمله شبکه های اجتماعی دانشگاه را فراهم می کند

نحوه نصب سرور RStudio در CentOS 7

نحوه نصب سرور RStudio در CentOS 7

RStudio Server نسخه وب RStudio است که مجموعه ای از ابزارهایی است که برای تسهیل کار برنامه نویسی با استفاده از زبان برنامه نویسی R طراحی شده است. در سه

نصب Bolt CMS در CentOS 7

نصب Bolt CMS در CentOS 7

Bolt یک CMS منبع باز است که به زبان PHP نوشته شده است. کد منبع Bolts در GitHub میزبانی شده است. این راهنما نحوه نصب Bolt CMS را در CentOS 7 Vult تازه نشان می دهد

نحوه نصب Elasticsearch در سرور Vultr CentOS 7

نحوه نصب Elasticsearch در سرور Vultr CentOS 7

Elasticsearch یک موتور جستجوی کامل و متن تحلیلی متن کامل است. به لطف تطبیق پذیری ، مقیاس پذیری و سهولت استفاده ، Elasticsearch گسترده تر است

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

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

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

راه اندازی Sails.js برای توسعه در CentOS 7

راه اندازی Sails.js برای توسعه در CentOS 7

با استفاده از یک سیستم متفاوت؟ مقدمه Sails.js یک چارچوب MVC ��رای Node.js است ، شبیه به Ruby on Rails. این امر برای ایجاد برنامه های مدرن ver

پیکربندی BGP با استفاده از Quagga در Vultr (CentOS 7)

پیکربندی BGP با استفاده از Quagga در Vultr (CentOS 7)

Vultrs عملکرد IP فضای شما را امکان پذیر می سازد تا آزادی بی سابقه ای در اختصاص منابع IP شخصی شما به سرورهای cloud Vultr داشته باشید. ما کلی

نحوه نصب PufferPanel (کنترل پنل کنکوری رایگان) در CentOS 7

نحوه نصب PufferPanel (کنترل پنل کنکوری رایگان) در CentOS 7

مقدمه در این آموزش ، PufferPanel را در Vultr VPS ما نصب کنید. PufferPanel یک پانل کنترل با منبع آزاد و بصورت رایگان برای مدیریت شما است

ابزارهای نظارت بهتر برای اوبونتو و CentOS

ابزارهای نظارت بهتر برای اوبونتو و CentOS

معرفی سیستم های لینوکس به طور پیش فرض مانند top ، df و du با ابزارهای نظارتی ارسال می شوند که به نظارت بر فرایندها و فضای دیسک کمک می کنند. با این حال ، اغلب اوقات ، آنها به صورت طاقت فرسا هستند

دستگاه های خود را با استفاده از LibreNMS در CentOS 7 نظارت کنید

دستگاه های خود را با استفاده از LibreNMS در CentOS 7 نظارت کنید

با استفاده از یک سیستم متفاوت؟ LibreNMS یک سیستم نظارت بر شبکه منبع باز کاملاً برجسته است. از SNMP برای به دست آوردن داده ها از دستگاه های مختلف استفاده می کند. یک نوع

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

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

با استفاده از یک سیستم متفاوت؟ Gitea یک منبع کنترل جایگزین متن باز و خود میزبان است که توسط Git ساخته شده است. Gitea در Golang نوشته شده و هست

نحوه نصب بستر سبد خرید 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 است. این برنامه یک رابط لعنتی مینیمالیستی و زیبا با نمای سلسله مراتب فهرست ارائه می دهد