1. 程式人生 > >jHipster開發中對配置文件.yo-ce.json分析

jHipster開發中對配置文件.yo-ce.json分析

size 分享 其中 命名 then framework 依賴 geb 一鍵生成

最近的項目開發是基於jHipster這個框架,借助這個框架快速部署基於Spring Boot + Angular Web的應用確實很痛快,不過,由於各種自動化配置,這樣會導致在快速的變更叠代過程中,遇到各種坑,是這樣的啦,前人造輪,後人乘車,車子出問題,找輪子兩眼一抹黑啦,這當然需要花相當多的時間去填上,這當然需要花相當多的時間去填上,這次主要是分析其中的一個配置文件,yo-ce.json這個文件,由於不熟悉其中的某些屬性,導致開發進度拖累,寫一份開發筆記記錄下
技術分享圖片
首先,我們知道這個是配置腳本是屬於yeoman體系,文件結構為json,接下來的分析都是基於yo-rc文件的api內容。這個文件存儲了多個生成器的配置文件,現在以jhipster中自動生成的配置文件為例

{
    "generator-jhipster": {
        "promptValues": {
            "packageName": "xxx.yyy.zzz"
        },
        "jhipsterVersion": "5.7.1",
        "applicationType": "monolith",
        "baseName": "zzz",
        "packageName": "xxx.yyy.zzz",
        "packageFolder": "xxx/yyy/zzz",
        "serverPort": "8080",
        "authenticationType": "jwt",
        "cacheProvider": "ehcache",
        "enableHibernateCache": true,
        "websocket": false,
        "databaseType": "sql",
        "devDatabaseType": "mariadb",
        "prodDatabaseType": "mariadb",
        "searchEngine": "elasticsearch",
        "messageBroker": false,
        "serviceDiscoveryType": "eureka",
        "buildTool": "gradle",
        "enableSwaggerCodegen": false,
        "jwtSecretKey": "YTJiY2Q3OTIyMjY3MDQ4M2I4ZGZiZjFhMGM3MjM5OTYzYmQzNzVkMWVhZTEzOTU2ZmQ5OGRkMDI0YTE1YzhmMGJlY2U4NWM3MGEzMGI4NjMxNDVhYjQyZWQ4MTMzMzc5NjlmY2NmNWRjZWU1MDQ0NGQ5MjJmNWY3YzMwY2M2MGM=",
        "clientFramework": "angularX",
        "useSass": true,
        "clientPackageManager": "npm",
        "testFrameworks": [],
        "jhiPrefix": "jhi",
        "otherModules": [],
        "enableTranslation": false,
        "skipServer": true, 
        "skipClient": true
    }
}

整份json文件,可以存儲來自多個生成器(generator)的配置對象,每個生成器都是有自己的命名空間的,以確保生成器之間不會發生命名沖突,不過這樣也導致了不通生成器之間並不能共享配置,這個到時可能也會有坑,此時暫且不提。項目中配置對象則是"generator-jhipster": {"promptValues": {"packageName": "com.smpteam.amzradar"}
配置文件中,詳細的記錄我們所采用的jhipster的版本號、應用類型、包的路徑、命名、開放的端口(8080)、身份校驗(JWT)、依賴的數據庫(mariadb)、建設倉庫(gradle)等內容。
這些東西都是自動化配置生成的,一開始就很爽了,快速搭建微服務,一鍵生成基於Spring Boot + Angular Web的開發環境,前端後臺一頓騷操作,然後再開發的過程中,不知道在何時的時候增加了配置文件中的最後一行"skipServer": true

這個會屬性會導致系統在重新生成依賴文件直接忽略服務內容,不會對其生成新的變更,相應的還有"skipClient": true,這個會忽略的是客戶端的變更。
加上這個屬性是為了快速生成新的文件,否則會將全局所有的文件覆蓋,因此這個屬性嘛,見仁見智了,看需求啦

內容參考
yeoman官方介紹文檔:https://yeoman.io/authoring/storage.html
https://blog.ippon.tech/how-to-efficiently-use-jhipster-in-your-company/

jHipster開發中對配置文件.yo-ce.json分析