腾讯云Centos9使用docker的方式安装APISIX

  1. 在虚拟机中安装Docker、Docker-compose
    1. 安装Docker
      1. 清除旧版本的docker

yum remove docker docker-client docker-client-latest docker-common docker-latest docker-latest-logrotate docker-logrotate docker-engine

      1. 安装docker的依赖

yum install -y yum-utils device-mapper-persistent-data lvm2

1.1.3 安装gcc

yum install -y gcc gcc-c++

      1. 添加软件源国内镜像

yum-config-manager --add-repo http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo

1.1.5 更新yum索引

yum makecache

1.1.6 安装docker-ce

yum install docker-ce docker-ce-cli containerd.io

1.1.7 启动docker,并设置开机启动

systemctl start docker

systemctl enable docker

1.1.8 验证docker的安装是否成功

docker version

1.2 安装Docker-compose

1.2.1下载docker-compose的二进制文件

1.2.1.1 查询虚拟机内核名和计算机硬件架构
1.2.1.2 下载地址

https://github.com/docker/compose/releases/tag/v2.21.0

1.2.1.3 将其迁移到/usr/local/bin目录下,并授予读写权限

chmod -R 777 /usr/local/bin/docker-compose

1.2.1.4 验证docker-compose的安装是否成功

docker-compose version

2、安装apisix

2.1 下载 apisix-docker仓库

git clone https://github.com/apache/apisix-docker.git

2.2 进入拉取的目录中

cd apisix-docker/example

2.3 修改docker-compose.yml文件内容

Licensed to the Apache Software Foundation (ASF) under one or more

contributor license agreements. See the NOTICE file distributed with

this work for additional information regarding copyright ownership.

The ASF licenses this file to You under the Apache License, Version 2.0

(the "License"); you may not use this file except in compliance with

the License. You may obtain a copy of the License at

http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software

distributed under the License is distributed on an "AS IS" BASIS,

WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.

See the License for the specific language governing permissions and

limitations under the License.

version: "3"

services:

apisix:

image: apache/apisix:${APISIX_IMAGE_TAG:-3.7.0-debian}

restart: always

volumes:

  • ./apisix_conf/config.yaml:/usr/local/apisix/conf/config.yaml:ro

depends_on:

  • etcd

##network_mode: host

ports:

  • "9180:9180/tcp"

  • "9080:9080/tcp"

  • "9091:9091/tcp"

  • "9443:9443/tcp"

  • "9092:9092/tcp"

networks:

apisix:

etcd:

image: bitnami/etcd:3.4.15

restart: always

volumes:

  • etcd_data:/bitnami/etcd

environment:

ETCD_ENABLE_V2: "true"

ALLOW_NONE_AUTHENTICATION: "yes"

ETCD_ADVERTISE_CLIENT_URLS: "http://43.139.54.145:2379"

ETCD_LISTEN_CLIENT_URLS: "http://0.0.0.0:2379"

ports:

  • "2379:2379/tcp"

networks:

apisix:

web1:

image: nginx:1.19.0-alpine

restart: always

volumes:

  • ./upstream/web1.conf:/etc/nginx/nginx.conf

ports:

  • "9081:80/tcp"

environment:

  • NGINX_PORT=80

networks:

apisix:

web2:

image: nginx:1.19.0-alpine

restart: always

volumes:

  • ./upstream/web2.conf:/etc/nginx/nginx.conf

ports:

  • "9082:80/tcp"

environment:

  • NGINX_PORT=80

networks:

apisix:

prometheus:

image: prom/prometheus:v2.25.0

restart: always

volumes:

  • ./prometheus_conf/prometheus.yml:/etc/prometheus/prometheus.yml

ports:

  • "9090:9090"

networks:

apisix:

grafana:

image: grafana/grafana:7.3.7

restart: always

ports:

  • "3000:3000"

volumes:

  • "./grafana_conf/provisioning:/etc/grafana/provisioning"

  • "./grafana_conf/dashboards:/var/lib/grafana/dashboards"

  • "./grafana_conf/config/grafana.ini:/etc/grafana/grafana.ini"

networks:

apisix:

networks:

apisix:

driver: bridge

volumes:

etcd_data:

driver: local

修改etcd的IP地址

43.139.54.145是腾讯云外网ip

2.4 使用docker-compose启用 APISIX

```

docker-compose -p docker-apisix up -d

2.5 查看apisix安装的情况

docker ps -a

3、安装apisix-dashboard

3.1 拉取apisix-dashboard镜像

docker pull apache/apisix-dashboard

3.2、在/root路径下,添加dashboard的配置文件conf.yaml

conf:

listen:

host: 0.0.0.0 # the address on which the `Manager API` should listen.

The default value is 0.0.0.0, if want to specify, please enable it.

This value accepts IPv4, IPv6, and hostname.

port: 9000 # The port on which the `Manager API` should listen.

allow_list: # If we don't set any IP list, then any IP access is allowed by default.

etcd:

endpoints: # supports defining multiple etcd host addresses for an etcd cluster

  • 10.0.12.9:2379

username: "root" #如果没开启授权,可以注掉

password: "root" #如果没开启授权,可以注掉

authentication:

secret:

zQ5w5jkLDh3jZpywJ3sskrw6Yv633ruq

expire_time: 3600 # jwt token expire time, in second

users: # yamllint enable rule:comments-indentation

  • username: admin

password: password

  • username: user

password: password

10.0.12.9是腾讯云内网ip

3.3 启动容器

cd /root

docker run -it -p 9000:9000 -v ./conf.yaml:/usr/local/apisix-dashboard/conf/conf.yaml apache/apisix-dashboard

3.4 查看容器启动情况

docker ps -a

4、测试

4.1 访问dashboard页面

访问地址:http://43.139.54.145:9000,账号密码为conf.yaml文件中的

4.2 访问到grafana的页面

Grafana,账号密码均为admin

4.3 访问prometheus页面

http://43.139.54.145:9090

5、防火墙

5.1 虚拟机防火墙

5.2 腾讯云服务器防火墙

相关推荐
Kendra91916 小时前
K8s集群组件启动不成功排查
云原生·容器·kubernetes
努力搬砖的咸鱼16 小时前
用 Minikube 或 Kind 在本地跑起 Kubernetes
微服务·云原生·容器·架构·kubernetes·kind
噎住佩奇16 小时前
单节点K8s集群中安装StorageClass(SC)
云原生·容器·kubernetes
不想画图17 小时前
Kubernetes(八)——PV和PVC
云原生·容器·kubernetes
Serverless社区17 小时前
探秘 AgentRun|基于 Serverless 的 AI Agent 沙箱工程化之路
运维·阿里云·云原生·serverless·函数计算
阿里云云原生18 小时前
Nacos 生产级安全实践:精细化鉴权、灰度平滑过渡与全量操作审计
安全·阿里云·云原生·nacos
咕噜企业分发小米21 小时前
腾讯云和火山引擎在多云管理工具方面的具体功能差异有哪些?
云计算·腾讯云·火山引擎
咕噜企业分发小米21 小时前
腾讯云和火山引擎在多云管理工具上如何实现成本优化?
java·腾讯云·火山引擎
Cyber4K1 天前
【Kubernetes专项】零故障升级之Pod健康探测
云原生·容器·kubernetes
咕噜企业分发小米1 天前
腾讯云在搭建平台的时候起什么作用
云计算·腾讯云