CentOS 7.x安裝微服務閘道器Apache APISIX
APISIX是一個雲原生、高效能、可擴充套件的微服務 API 閘道器。它是基於 OpenResty和etcd來實現,和傳統API閘道器相比,APISIX具備動態路由和外掛熱載入,特別適合微服務體系下的API管理。APISIX通過外掛機制,提供動態負載平衡、身份驗證、限流限速等功能,並且支援你自己開發的外掛。
APISIX是基於雲原生的微服務API閘道器,它是所有業務流量的入口,可以處理傳統的南北向流量(server-client),也可以處理服務間的東西向流量(server-server),也可以當做 k8s ingress controller 來使用。
圖片來源:官網
https://gitee.com/iresty/apisix
流量流向方向:通常核心網路元件繪製在頂部(NORTH),客戶端繪製在底部(SOUTH),而資料中心內的不同伺服器水平(EAST-WEST)繪製。
0x01:安裝APISIX服務
-
先安裝依賴服務
# 安裝 epel, `luarocks` 需要它
wgethttp://dl.fedoraproject.org/pub/epel/epel-release-latest-7.noarch.rpm
rpm-ivhepel-release-latest-7.noarch.rpm
# 新增 OpenResty 源
yuminstallyum-utils
yum-config-manager--add-repo\
https://openresty.org/package/centos/openresty.repo
# 安裝 OpenResty, etcd 和 編譯工具
yuminstall-yetcdopenrestycurlgitgccluarockslua-devel
# 開啟 etcd server
systemctlstartetcd
如果在訪問過程中遇到訪問不到的問題可以,可以試著關閉一下防火牆和selinux
# 防火牆關閉
systemctlstopfirewalld.service
systemctldisablefirewalld.service
# 關閉selinux
setenforce0
sed-i's/SELINUX=enforcing/SELINUX=disabled/'/etc/selinux/config
-
安裝APISIX
yuminstall-yhttps://github.com/apache/incubator-apisix/releases/download/1.3/apisix-1.3-0.el7.noarch.rpm
-
啟動和關閉apisix
apisixstart
apisixstop
-
檢視服務是否啟動
檢視程序或者監聽埠9080
#檢視程序
psaux|grepapisix
#檢視埠
netstat-lntp|grep9080
0x02:安裝控制檯apisix-dashboard
新版本的APISIX已經內建了dashboard視覺化WEB控制檯,可以很直觀的看到各種router配置、upstream配置等等。瀏覽器直接訪問就可以開啟dashboard:
http://127.0.0.1:9080/apisix/dashboard
以下步驟是基於APISIX一些低版本沒有內建apisix-dashboard控制檯的情況,安裝apisix-dashboard控制檯。此控制檯頁面基於VUE開發,需要通過yarn編譯生成。官網地址
https://github.com/apache/incubator-apisix-dashboard
安裝基礎編譯環境:node npm yarn
-
安裝node和npm
#下載
wgethttps://nodejs.org/dist/v12.16.1/node-v12.16.1-linux-x64.tar.xz
#解壓部署
tarxvfnode-v12.16.1-linux-x64.tar.xz
mvnode-v12.16.1-linux-x64/usr/local/node
#配置環境變數
echo'PATH=/usr/local/node/bin/:$PATH'>>/etc/profile
source/etc/profile
#測試環境是否安裝成功
node--version
npm--version
-
安裝yarn
# 下載
wgethttps://github.com/yarnpkg/yarn/releases/download/v1.22.4/yarn-v1.22.4.tar.gz
#解壓部署
tarxvfyarn-v1.22.4.tar.gz
mvyarn-v1.22.4/usr/local/yarn
#配置環境變數
echo'PATH=/usr/local/yarn/bin/:$PATH'>>/etc/profile
source/etc/profile
#測試環境是否安裝成功
yarn--version
-
編譯dashboard元件,生成靜態頁面
# git獲取原始碼
gitclonehttps://github.com/apache/incubator-apisix-dashboard.git
cdincubator-apisix-dashboard
#切換分支版本和apisix版本一致即可
gitcheckout1.0
#下載解決依賴包
yarn
#構建生成頁面
yarnbuild:prod
#複製到訪問路徑
mkdir-p/usr/local/apisix/dashboard
cp-r./*/usr/local/apisix/dashboard
-
驗證是否安裝成功
http://127.0.0.1:9080/apisix/dashboard/
0x03:測試驗證
-
隨便找一個服務,這裡啟動一個nacos配置服務
-
登入apisix-dashboard控制檯
http://127.0.0.1:9080/apisix/dashboard/
-
配置指向後端服務的upstream
-
配置路由規則資訊Routes
-
驗證方向代理
訪問http://127.0.0.1:9080/nacos/
9080是apisix服務的埠;/nacos/是配置的路由規則,只要/nacos/打頭的都轉發到http://192.168.56.1:8848/nacos/處理。
通過上圖,可以檢視到已經轉發成功,說明反向代理設定成功。另外可以新增多節點進行負載均衡