常见问题
如何对服务进行扩缩容?
扩缩容服务无需调整 erda.yml
,直接在部署中心操作即可。
进入 DevOps 平台 > 我的应用 > 部署中心,选择 服务扩容。
根据需要进行服务资源调整。
服务是否提供内部调用的地址?
进入 DevOps 平台 > 我的应用 > 部署中心 可查看服务的内部地址。
服务的重新部署或流水线的重新构建均不会影响该内部地址。
如何查看错误日志?
进入 DevOps 平台 > 我的应用 > 部署中心,点击容器日志,此时显示的是标准输出(stdout)日志。
点击顶部切换开关,查看标准错误(stderr)日志。
如何查看已停止的容器实例?
进入 DevOps 平台 > 我的应用 > 部署中心,选择 已停止 查看对应容器实例。
状态栏中标注了容器停止的原因(如 OOM 退出,此处将标注为 OOMKilled)。操作栏中可以查看容器运行时的资源使用情况以及对应日志。
如何复用 Addon?
基于 Addon 的名称进行复用,例如 erda.yml
中有如下描述,则 redis-abc
即该 Addon 的名称:
addons:
redis-abc:
plan: redis:basic
使用 API 网关进行转发,页面重定向失败怎么办?
失败原因一般为使用了请求头中的 Host
,建议使用 X-Forwarded-Host
进行替代,或者开启 API 网关的域名透传,步骤如下:
进入 微服务治理平台 > API 网关 > 流量入口管理,选择对应流量入口详情,点击 全局策略。
进入 业务策略 > 流量接收转发,启用规则后开启 入口域名透传。
如何对特定域名或 API 控制 HTTPS 强制跳转?
进入 微服务治理平台 > API 网关 > 流量入口管理,点击对应流量入口详情,选择 全局策略 或 策略。(全局策略对该流量入口下所有 API 生效,具体 API 策略仅对该 API 生效。)
进入 业务策略 > 流量接收转发,启用规则后开启 强制跳转HTTPS。
::: tip
若在 SLB 等外部负载均衡设备上,已配置 80 端口强制 HTTPS 跳转,则 Erda 上的跳转功能无效。
:::
如何在容器中使用存储?
场景一:多个容器需共享某些特定文件(如支付证书)时,一个应用的多个实例将共享一块存储,对支付证书进行存取。
erda.yml
中的配置参考如下:volumes:
- storage: nfs
path: /data/cert
场景二:部署一个需持久化存储的服务时(如 Oracle),可以在
erda.yml
中声明一块 Local 类型的 Volumes,则该 Pod 重启后将再次分配到当前宿主机上。volumes:
- storage: local
path: /u01/app/oracle
如何确定一个容器的出口 IP?
当部署在 Erda 上的应用需调用外部接口(如支付接口)时,第三方服务通常需获取公网的出口 IP 来定位问题,此时可在容器控制台中执行以下命令:
```shell script curl ifconfig.me
![](https://terminus-paas.oss-cn-hangzhou.aliyuncs.com/paas-doc/2021/08/18/4171251f-9165-4b7a-b4de-bcb6a52aa41d.png)
## 平台支持 Java 11 吗?
支持,可通过指定 `container_version` 切换运行容器的 JDK 版本。目前支持 JDK 1.8 和 11 两个版本 。
`pipeline.yml` 中的配置如下:
- java:
params:
```build_type: maven # 打包类型,这里选用 maven 打包
workdir: ${git-checkout} # 打包时的当前路径,此路径一般为根 pom.xml 的路径
options: -am -pl user # maven 打包参数,比如打包 user 模块使用命令 `mvn clean package -am -pl user`,这里省略命令 `mvn clean package` 只需要填写参数
target: ./user/target/user.jar # 打包产物,一般为 jar,填写相较于 workdir 的相对路径。文件必须存在,否则将会出错。
container_type: spring-boot # 运行 target(如 jar)所需的容器类型,比如这里我们打包的结果是 spring-boot 的 fat jar,故使用 spring-boot container
#container_version: v1.8.0.181 # 可选: v1.8.0.181, v11.0.6, 默认 v1.8.0.181