iOS Developer的全棧之路 - Keycloak(10)

這一節(jié)中,我們來看看如何為Keycloak配置數(shù)據(jù)庫(kù)席噩。默認(rèn)情況下媳瞪,Keycloak使用的是輕量級(jí)的內(nèi)嵌數(shù)據(jù)庫(kù)H2何之,作為學(xué)習(xí)是足夠的,但在生成環(huán)境下還需為其配置功能更強(qiáng)大的關(guān)系型數(shù)據(jù)庫(kù)。

Keycloak數(shù)據(jù)持久化使用了兩層結(jié)構(gòu),底層為JDBC用于連接具體的數(shù)據(jù)庫(kù),上層為Hibernate JPA开睡,用于實(shí)現(xiàn)ORM。在本節(jié)中苟耻,我們將使用Posgres作為示例進(jìn)行演示篇恒,配置如下:

  1. Keycloak 8.0.1
  2. Docker (用于運(yùn)行數(shù)據(jù)庫(kù)實(shí)例)
  3. Postgres 9.6.17
  4. JDBC driver postgresql-42.2.11

使用Docker運(yùn)行本地?cái)?shù)據(jù)庫(kù)

使用了官方的鏡像postgres:9.6.17,運(yùn)行如下命令
docker run -p 5432:5432 --name my-postgres -e POSTGRES_PASSWORD=123456 -e POSTGRES_USER=root -e POSTGRES_DB=keycloak -d postgres:9.6.17
其中通過-e來指定了用戶名和密碼凶杖,同時(shí)配置了初始的數(shù)據(jù)庫(kù)keycloak胁艰。運(yùn)行后,可使用Navcat來查看數(shù)據(jù)庫(kù)是否正常運(yùn)行。

配置JDBC driver

地址為:https://jdbc.postgresql.org/download.html在這里給出了不同的driver版本腾么,官方建議沒有特殊需求可直接使用最新的版本奈梳,此時(shí)最新的為42.2.11。同時(shí)還需要注意JDBC 4.x的版本需要解虱,由于Keycloak使用的是Java 8攘须,所以可以采用JDBC 4.2。

下載后需要把該jar包放在指定的位置殴泰,路徑為:keycloak-8.0.1/modules/system/layers/keycloak/org/postgresql/main/postgresql-42.2.11.jar于宙,此時(shí)會(huì)發(fā)現(xiàn)在org下并沒有postgresql目錄,手動(dòng)創(chuàng)建即可悍汛。同時(shí)還需要為其添加配置文件捞魁,目的是讓wildfly可以讀取到該JDBC driver,配置文件和jar包在同一目錄下即可:

<?xml version="1.0" ?>
<module xmlns="urn:jboss:module:1.3" name="org.postgresql">

    <resources>
        <resource-root path="postgresql-42.2.11.jar"/>
    </resources>

    <dependencies>
        <module name="javax.api"/>
        <module name="javax.transaction.api"/>
    </dependencies>
</module>

由于在同級(jí)目錄下离咐,resource-root path直接賦值為當(dāng)前的jar文件名谱俭。

配置DataSource

為了讓Keycloak啟動(dòng)后可以直接使用到我們外置的數(shù)據(jù)庫(kù),需要將原先使用H2的配置宵蛀,更改為Postgres昆著。根據(jù)不同的部署方式术陶,需要更改不同的配置文件凑懂,對(duì)于單體應(yīng)用而言,需要修改standalone/configuration/standalone.xml瞳别,而對(duì)于集群部署征候,則需要修改standalone/configuration/standalone-ha.xml杭攻。在配置文件中祟敛,可根據(jù)關(guān)鍵詞datasource進(jìn)行搜索

<subsystem xmlns="urn:jboss:domain:datasources:5.0">
    <datasources>
        <datasource jndi-name="java:jboss/datasources/ExampleDS" pool-name="ExampleDS" enabled="true" use-java-context="true" statistics-enabled="${wildfly.datasources.statistics-enabled:${wildfly.statistics-enabled:false}}">
            <connection-url>jdbc:h2:mem:test;DB_CLOSE_DELAY=-1;DB_CLOSE_ON_EXIT=FALSE</connection-url>
            <driver>h2</driver>
            <security>
                <user-name>sa</user-name>
                <password>sa</password>
            </security>
        </datasource>
        <datasource jndi-name="java:jboss/datasources/KeycloakDS" pool-name="KeycloakDS" enabled="true" use-java-context="true" statistics-enabled="${wildfly.datasources.statistics-enabled:${wildfly.statistics-enabled:false}}">
            <connection-url>jdbc:postgresql://localhost:5432/keycloak</connection-url>
            <driver>postgresql</driver>
            <pool>
                <max-pool-size>20</max-pool-size>
            </pool>
            <security>
                <user-name>root</user-name>
                <password>123456</password>
            </security>
        </datasource>
        <drivers>
            <driver name="postgresql" module="org.postgresql">
                <xa-datasource-class>org.postgresql.xa.PGXADataSource</xa-datasource-class>
            </driver>
            <driver name="h2" module="com.h2database.h2">
                <xa-datasource-class>org.h2.jdbcx.JdbcDataSource</xa-datasource-class>
            </driver>
        </drivers>
    </datasources>
</subsystem>

在drivers這個(gè)tag下,原先只有h2兆解,此時(shí)我們添加了postgresql馆铁。同時(shí)在上方的datasource中,將KeycloakDS下的配置也需要修改為postgresql锅睛。這里的配置無(wú)需過多說明埠巨,比較容易理解。

此外還有關(guān)于數(shù)據(jù)庫(kù)的一些配置现拒,如初始化方式辣垒,migration策略等,可以保持默認(rèn)即可:

<spi name="connectionsJpa">
    <provider name="default" enabled="true">
        <properties>
            <property name="dataSource" value="java:jboss/datasources/KeycloakDS"/>
            <property name="initializeEmpty" value="true"/>
            <property name="migrationStrategy" value="update"/>
            <property name="migrationExport" value="${jboss.home.dir}/keycloak-database-update.sql"/>
        </properties>
    </provider>
</spi>

initializeEmpty:當(dāng)數(shù)據(jù)庫(kù)為空時(shí)印蔬,是否自動(dòng)進(jìn)行初始化勋桶,若設(shè)置為false,則需要手動(dòng)進(jìn)行初始化。
migrationStrategy:migration策略例驹,可選的有update, manual 和 validate捐韩。

檢驗(yàn)

配置完成后,運(yùn)行./standalone.sh即可運(yùn)行鹃锈,通過Navcat可以查看到Keycloak默認(rèn)創(chuàng)建的表:

image.png

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末荤胁,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子屎债,更是在濱河造成了極大的恐慌仅政,老刑警劉巖,帶你破解...
    沈念sama閱讀 218,858評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件扔茅,死亡現(xiàn)場(chǎng)離奇詭異已旧,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)召娜,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,372評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門运褪,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人玖瘸,你說我怎么就攤上這事秸讹。” “怎么了雅倒?”我有些...
    開封第一講書人閱讀 165,282評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵璃诀,是天一觀的道長(zhǎng)。 經(jīng)常有香客問我蔑匣,道長(zhǎng)劣欢,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,842評(píng)論 1 295
  • 正文 為了忘掉前任裁良,我火速辦了婚禮凿将,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘价脾。我一直安慰自己牧抵,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,857評(píng)論 6 392
  • 文/花漫 我一把揭開白布侨把。 她就那樣靜靜地躺著犀变,像睡著了一般。 火紅的嫁衣襯著肌膚如雪秋柄。 梳的紋絲不亂的頭發(fā)上获枝,一...
    開封第一講書人閱讀 51,679評(píng)論 1 305
  • 那天,我揣著相機(jī)與錄音骇笔,去河邊找鬼省店。 笑死机隙,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的萨西。 我是一名探鬼主播有鹿,決...
    沈念sama閱讀 40,406評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼谎脯!你這毒婦竟也來了葱跋?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,311評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤源梭,失蹤者是張志新(化名)和其女友劉穎娱俺,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體废麻,經(jīng)...
    沈念sama閱讀 45,767評(píng)論 1 315
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡荠卷,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,945評(píng)論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了烛愧。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片油宜。...
    茶點(diǎn)故事閱讀 40,090評(píng)論 1 350
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖怜姿,靈堂內(nèi)的尸體忽然破棺而出慎冤,到底是詐尸還是另有隱情,我是刑警寧澤沧卢,帶...
    沈念sama閱讀 35,785評(píng)論 5 346
  • 正文 年R本政府宣布蚁堤,位于F島的核電站,受9級(jí)特大地震影響但狭,放射性物質(zhì)發(fā)生泄漏披诗。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,420評(píng)論 3 331
  • 文/蒙蒙 一立磁、第九天 我趴在偏房一處隱蔽的房頂上張望呈队。 院中可真熱鬧,春花似錦息罗、人聲如沸掂咒。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,988評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至温圆,卻和暖如春挨摸,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背岁歉。 一陣腳步聲響...
    開封第一講書人閱讀 33,101評(píng)論 1 271
  • 我被黑心中介騙來泰國(guó)打工得运, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留膝蜈,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,298評(píng)論 3 372
  • 正文 我出身青樓熔掺,卻偏偏與公主長(zhǎng)得像饱搏,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子置逻,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,033評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容

  • Druid的簡(jiǎn)介 Druid首先是一個(gè)數(shù)據(jù)庫(kù)連接池券坞。Druid是目前最好的數(shù)據(jù)庫(kù)連接池鬓催,在功能、性能恨锚、擴(kuò)展性方面宇驾,...
    _雙眸閱讀 1,708評(píng)論 0 5
  • 1. 簡(jiǎn)介 1.1 什么是 MyBatis ? MyBatis 是支持定制化 SQL猴伶、存儲(chǔ)過程以及高級(jí)映射的優(yōu)秀的...
    笨鳥慢飛閱讀 5,523評(píng)論 0 4
  • 在我們?cè)噲D將Keycloak引入一個(gè)已用項(xiàng)目時(shí)课舍,通常項(xiàng)目已有用戶系統(tǒng),如果要進(jìn)行完整的用戶系統(tǒng)遷移他挎,migrate...
    西西的一天閱讀 1,321評(píng)論 0 1
  • 一. Java基礎(chǔ)部分.................................................
    wy_sure閱讀 3,811評(píng)論 0 11
  • 冰壺感悟:1懂了之后布卡,才有可能產(chǎn)生興趣。以前覺得冰壺太無(wú)聊了雇盖,其實(shí)是因?yàn)樽约翰欢薜取9舛?guī)則也不行,自己參與進(jìn)來崔挖,自...
    李少鋒閱讀 699評(píng)論 0 0