前言
本文基于nacos 1.0.1版本
小聲BB:懶得弄排版了牍蜂,直接上筆記
- Nacos昭殉,如果使用高版本的 mysql佳魔, 啟動時(shí)需要把mysql-connector放到plugin/mysql文件夾下鸿市,因?yàn)轫?xiàng)目默認(rèn)依賴的mysql-connector 5.1.34嘁酿,所以會導(dǎo)致驅(qū)動不生效而連接失敗
原因:com.alibaba.nacos.config.server.service.BasicDataSourceServiceImpl
這個(gè)類中有設(shè)定好老版本和高版本的mysql驅(qū)動路徑廊镜,如下
static {
try {
Class.forName(MYSQL_HIGH_LEVEL_DRIVER);
JDBC_DRIVER_NAME = MYSQL_HIGH_LEVEL_DRIVER;
log.info("Use Mysql 8 as the driver");
} catch (ClassNotFoundException e) {
log.info("Use Mysql as the driver");
JDBC_DRIVER_NAME = DEFAULT_MYSQL_DRIVER;
}
}
如果是直接在編譯器中啟動該程序的話牙肝,需要找到nacos-all/pom.xml 里修改mysql-connector的version,如果是直接從程序包里啟動的話嗤朴,則將jar包添加到plugins/mysql 即可
P.S. 由于連接DB失敗并不影響應(yīng)用啟動配椭,但是會導(dǎo)致設(shè)定好的登陸用戶名密碼無法使用,所以如果發(fā)現(xiàn)用戶名密碼設(shè)定失敗的話雹姊,去查看日志會發(fā)現(xiàn)有可能就是SB的問題
-
補(bǔ)充1.:淦股缸,用了上述的方法毫無作用,還是連不上數(shù)據(jù)庫吱雏,必須要自己重新編譯敦姻,這項(xiàng)目有坑,無法兼容高版本MYSQL
com.alibaba.nacos.naming.healthcheck
import com.mysql.jdbc.jdbc2.optional.MysqlDataSource;
這個(gè)地方必須低版本MYSQL才有這個(gè)類歧杏,高版本的路徑已經(jīng)變了
所以上面這段兼容代碼完全木有卵用
-
windows的cmd腳本里默認(rèn)了是stand alone單機(jī)模式的镰惦,想要在windows下測試集群得修改startup.cmd腳本,里面的MODE改成默認(rèn)cluster集群模式
Just like this
BAT代碼 Nacos 支持環(huán)境隔離犬绒,參考阿里的nacos blog
https://nacos.io/zh-cn/blog/address-server.html關(guān)于1.和2.的補(bǔ)充旺入,查看update log里說1.0.0已經(jīng)支持MYSQL 8的driver了,然而我用1.0.1還是不行……issue里貌似也有不少抱怨的,先不管了
nacos-config 就是一個(gè)配置中心的作用茵瘾,用于分布式全局配置的作用礼华,實(shí)際上跟.properties文件的屬性配置類似,但它可以用于分布式環(huán)境中的集中式中心配置的作用拗秘,例如在nacos集群中配置好了相應(yīng)的屬性圣絮,那么應(yīng)用程序中可以直接通過注解式的代碼進(jìn)行訪問,單臺nacos服務(wù)器配置的屬性可以自動同步到整個(gè)集群
Just like this:
@RefreshScope
class SampleController {
@Value("${user.name}")
String userName;
@Value("${user.age}")
int age;
}
如上的代碼中的user.name和age就是從配置中心中獲得的聘殖,更多細(xì)節(jié)參考:
https://github.com/spring-cloud-incubator/spring-cloud-alibaba/blob/master/spring-cloud-alibaba-examples/nacos-example/nacos-config-example/readme-zh.md
Nacos-config 的配置有部分是先于application就開始使用的晨雳,所以必須要寫在bootstrap.properties上,如果寫到application.properties上會撲街
Nacos 集群模式搭建的時(shí)候奸腺,有可能會因?yàn)榫钟蚓W(wǎng)的網(wǎng)卡問題導(dǎo)致集群leader選舉失敗餐禁,需要進(jìn)行網(wǎng)卡設(shè)置,具體參考文檔中的https://nacos.io/zh-cn/docs/deployment.html
關(guān)于8的補(bǔ)充突照,我使用了網(wǎng)卡配置帮非,開啟了局域網(wǎng)IP選項(xiàng)為true,并且設(shè)置了127.0.0.1為本機(jī)IP讹蘑,日志顯示集群選舉成功末盔,但是服務(wù)注冊依舊撲街,返回503 server is down座慰,翻issue發(fā)現(xiàn)是bughttps://github.com/alibaba/nacos/issues/1189陨舱,維護(hù)者說是1.0.0的bug,將會在1.0.1 fix版仔,然鵝在下使用的1.0.1了還是有這個(gè)bug游盲,但是暫時(shí)不知道是不是跟我單機(jī)環(huán)境開啟集群造成的問題,后續(xù)有了測試服務(wù)器再嘗試
最后解決的方法是使用了網(wǎng)絡(luò)上的ip蛮粮,設(shè)置局域網(wǎng)IP開關(guān)為false益缎,結(jié)果就注冊成功了,先記錄下ConfigService不能直接得到然想,要通過NacosConfigProperties注入然后configServiceInstance()方法獲得
nacos的SDK提供了配置中心和服務(wù)中心的操作API莺奔,基本的CRUD操作都有,具體查看https://nacos.io/zh-cn/docs/sdk.html
nacos集成了spring cloud的ribbon和feign变泄,可以直接用它們來做基礎(chǔ)的RPC令哟。RPC的URL中記得加入目標(biāo)服務(wù)的context-root,因?yàn)閺膎acos里獲取到的只有一個(gè)IP妨蛹,實(shí)例化請求的時(shí)候url如果沒有context-root就無法指向到正確的接口內(nèi)
nacos默認(rèn)有一個(gè)nacos/nacos的賬號密碼励饵,會在nacos實(shí)例第一次啟動時(shí)自動生成數(shù)據(jù)到users表中,可以將其刪除滑燃,然后使用
org.springframework.security.crypto.bcrypt.BCryptPasswordEncoder這個(gè)類,類似:
System.out.println(new BCryptPasswordEncoder().encode("password"));
來生成密碼颓鲜,該工具類在spring-security-core包中有表窘,然后在users表中插入賬號密碼典予,賬號明文存儲,密碼則使用加密后的字符串存入乐严,然后在roles表中給對應(yīng)賬號插入ROLE_ADMIN瘤袖,則可以新建管理員賬號