欢迎来到代码驿站!

JAVA代码

当前位置:首页 > 软件编程 > JAVA代码

详解JavaEE中Apollo安装使用小结

时间:2022-07-28 11:01:06|栏目:JAVA代码|点击:

说明:

Apollo是配置管理中心,和SpringCloud-Config实现的功能有点相似。

一、安装MySQL 5.7.37(主机:192.168.233.128,用户/密码:root):

1.下载mysql-5.7.37-1.el7.x86_64.rpm-bundle.tar,并上传到centos7:

https://dev.mysql.com/downloads/mysql/

解压mysql-5.7.37-1.el7.x86_64.rpm-bundle.tar(cd到/root目录):

[root@localhost ~]# tar -xvf mysql-5.7.37-1.el7.x86_64.rpm-bundle.tar 

2.安装依赖:

[root@localhost ~]# yum -y install libaio
[root@localhost ~]# yum -y install perl
[root@localhost ~]# yum -y install net-tools

3.安装mysql:

[root@localhost ~]# rpm -ivh mysql-community-common-5.7.37-1.el7.x86_64.rpm
[root@localhost ~]# rpm -ivh mysql-community-libs-5.7.37-1.el7.x86_64.rpm
[root@localhost ~]# rpm -ivh mysql-community-client-5.7.37-1.el7.x86_64.rpm
[root@localhost ~]# rpm -ivh mysql-community-server-5.7.37-1.el7.x86_64.rpm
[root@localhost ~]# rpm -ivh mysql-community-libs-compat-5.7.37-1.el7.x86_64.rpm

4.启动:

[root@localhost ~]# service mysqld start

5.查看临时密码:

[root@localhost ~]# grep password /var/log/mysqld.log

6.登录(在Enter password输入上方查看的密码):

[root@localhost ~]# mysql -u root -p
Enter password: 

7.修改密码(密码:root):

mysql> ALTER USER 'root'@'localhost' IDENTIFIED WITH MYSQL_NATIVE_PASSWORD BY 'Root123456=';
mysql> SET GLOBAL validate_password_length=2;
mysql> SET GLOBAL validate_password_policy=0;
mysql> ALTER USER 'root'@'localhost' IDENTIFIED WITH MYSQL_NATIVE_PASSWORD BY 'root';

8.允许远程访问:

mysql> GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY 'root' WITH GRANT OPTION;

二、Apollo安装/启动(centos7)(主机:192.168.233.128):

1.下载apollo-quick-start-1.9.2.zip:

https://www.apolloconfig.com/#/zh/deployment/quick-start?id=%e4%ba%8c%e3%80%81%e5%ae%89%e8%a3%85%e6%ad%a5%e9%aa%a4

2.创建ApolloPortalDB、ApolloConfigDB数据库:

(1)使用Navicat连接mysql5,创建ApolloPortalDB、ApolloConfigDB数据库:

注:ApolloPortalDB在生产环境部署,而ApolloConfigDB需要每个环境部署一套。

(2)导入apolloportaldb.sql到ApolloPortalDB数据库(sql文件在apollo-quick-start-1.9.2/sql目录中):

使用Navicat右击ApolloPortalDB数据库,运行 SQL 文件,选择apolloportaldb.sql,点开始按钮。

(3)导入apolloconfigdb.sql到ApolloConfigDB数据库(sql文件在apollo-quick-start-1.9.2/sql目录中):

使用Navicat右击ApolloConfigDB数据库,运行 SQL 文件,选择apolloconfigdb.sql,点开始按钮。

3.安装Apollo:

(1)将apollo-quick-start-1.9.2.zip上传到/usr/local/apollo目录(mkdir /usr/local/apollo)。

(2)解压apollo-quick-start-1.9.2.zip(cd /usr/local/apollo/):

[root@localhost apollo]# unzip apollo-quick-start-1.9.2.zip

(3)配置ApolloPortalDB、ApolloConfigDB数据库连接信息:

[root@localhost apollo]# vi demo.sh

修改如下内容:

#ApolloConfigDB连接信息
apollo_config_db_url="jdbc:mysql://192.168.233.128:3306/ApolloConfigDB?characterEncoding=utf8&serverTimezone=Asia/Shanghai"
apollo_config_db_username=root
apollo_config_db_password=root
#ApolloPortalDB连接信息
apollo_portal_db_url="jdbc:mysql://192.168.233.128:3306/ApolloPortalDB?characterEncoding=utf8&serverTimezone=Asia/Shanghai"
apollo_portal_db_username=root
apollo_portal_db_password=root
...
# meta server url
config_server_url=http://192.168.233.128:8080
admin_server_url=http://192.168.233.128:8090
...
portal_url=http://192.168.233.128:8070

4.启动/停止Apollo:

[root@localhost apollo]# ./demo.sh start[root@localhost apollo]# ./demo.sh stop

5.打开Apollo首页(用户apollo,密码admin):

http://192.168.233.128:8070

三、Web应用接入Apollo(SpringBoot):

1.在Apollo中创建应用:

(1)在首页,点左上角"创建应用",输入AppId值等(此处AppId与待接入应用application.yml的app.id对应):

 (2)进入创建的应用,点击Key/Value列表的右上角"新增配置",添加Key和Value:

 (3)创建Key+Value后,回到Key/Value列表中,点右上角靠左的"发布"按钮生效:

 2.Web工程中配置Apollo信息:

(1)添加apollo依赖:

<dependencies>
    <dependency>
        <groupId>com.ctrip.framework.apollo</groupId>
        <artifactId>apollo-client</artifactId>
        <version>1.9.2</version>
    </dependency>
    <dependency>
        <groupId>com.ctrip.framework.apollo</groupId>
        <artifactId>apollo-openapi</artifactId>
        <version>1.9.2</version>
    </dependency>
</dependencies>

(2)配置app.id与app.meta,在application.yml中:

...
app:
  id: apollo                         #apollo应用ID(必须与Apollo网页上创建项目时定义的应用Id一致)
apollo:
  meta: http://192.168.233.128:8080  #apollo服务器地址
  autoUpdateInjectedSpringProperties: true  #false时@Value("${key1}")值不会自动更新,默认true自动更新
 #cache-dir: /opt/data/some-cache-dir       #自定义本地缓存路径,默认为/opt/data/{appId}/config-cache
  access-key:
    secret: 838fe62c502a43e2b70a31d7c7156f10 #配置访问密钥,在Apollo首页-管理密钥中创建密钥
  property:
    names:
      cache:
        enable: true   #开启propertyNames缓存
  bootstrap:
    enabled: true   #开启 Apollo
    namespaces: application  #可以注入多个命名空间,以逗号分隔
    #eagerLoad:
    #  enabled: true   #将apollo初始化放在日志系统初始化之前

(3)Application启动类添加@EnableApolloConfig注解:

@SpringBootApplication
@EnableApolloConfig   //开启Apollo
public class ApolloApplication {
    public static void main(String[] args) {
        SpringApplication.run(ApolloApplication.class);
    }
}

(4)Config方式获取apollo配置中心的配置:

@Configuration
public class ApolloConfig {
    @Value("${key1}")//从apollo配置中心获取添加的key1
    public String key1;
}

(5)获取key1并打印的测试Conrtoller:

@RestController
public class UserController {
    @Autowired
    private ApolloConfig apolloConfig;
    @RequestMapping("/user")
    @ResponseBody
    public String user(){
        return apolloConfig.key1;
    }
}

3.启动Web应用,需要添加Apollo环境+地址参数:

(1)IntelliJ IDEA方式,Edit Configurations -> 左侧Application中选中ApolloApplication,右侧Configuration选项卡中,在VM options中填入:

-Dapollo.meta=http://192.168.233.128:8080 -Denv=dev

(2)运行jar包方式,展开IntelliJ IDEA右侧Maven -> 找到apollo模块Lifecycle菜单,分别双击clean、install,将target目录下生成的apollo.jar上传到centos7,并使用java命令启动:

[root@localhost ~]# java -jar -Dapollo.meta=http://192.168.233.128:8080 -Denv=dev apollo.jar &

(3)访问Web应用"/user"接口显示获取到的key1值可以看到效果(不停止Web应用,修改Apollo配置中心的key1值,重新发布,再刷新以下接口,可以看到值已经变成新的了):

http://192.168.233.128:10006/user

上一篇:Java中的HashMap为什么会产生死循环

栏    目:JAVA代码

下一篇:Spring Data Jpa 中原生查询 REGEXP 的使用详解

本文标题:详解JavaEE中Apollo安装使用小结

本文地址:http://www.codeinn.net/misctech/209129.html

推荐教程

广告投放 | 联系我们 | 版权申明

重要申明:本站所有的文章、图片、评论等,均由网友发表或上传并维护或收集自网络,属个人行为,与本站立场无关。

如果侵犯了您的权利,请与我们联系,我们将在24小时内进行处理、任何非本站因素导致的法律后果,本站均不负任何责任。

联系QQ:914707363 | 邮箱:codeinn#126.com(#换成@)

Copyright © 2020 代码驿站 版权所有