來架個網站吧-13.網站開發-3: 設定環境參數-2

2024-02-28 來架個網站吧 linux 2023 iThome 鐵人賽

來架個網站吧-13.網站開發-3: 設定環境參數-2

tags: 來架個網站吧 Grails

我是目錄


昨天本來想要一口氣講完,但是發現篇幅好像有點長,所以決定切兩部份。

設定專案環境參數

grails-app/conf/application.yml

---
grails:
    profile: web
    codegen:
        defaultPackage: ironman.dict
    gorm:
        reactor:
            # Whether to translate GORM events into Reactor events
            # Disabled by default for performance reasons
            events: false
info:
    app:
        name: '@info.app.name@'
        version: '@info.app.version@'
        grailsVersion: '@info.app.grailsVersion@'
spring:
    jmx:
        unique-names: true
    main:
        banner-mode: "off"
    groovy:
        template:
            check-template-location: false
    devtools:
        restart:
            additional-exclude:
                - '*.gsp'
                - '**/*.gsp'
                - '*.gson'
                - '**/*.gson'
                - 'logback.groovy'
                - '*.properties'
environments:
    development:
        management:
            endpoints:
                enabled-by-default: true
                web:
                    base-path: '/actuator'
                    exposure:
                        include: '*'
    production:
        management:
            endpoints:
                enabled-by-default: false

---
grails:
    mime:
        disable:
            accept:
                header:
                    userAgents:
                        - Gecko
                        - WebKit
                        - Presto
                        - Trident
        types:
            all: '*/*'
            atom: application/atom+xml
            css: text/css
            csv: text/csv
            form: application/x-www-form-urlencoded
            html:
              - text/html
              - application/xhtml+xml
            js: text/javascript
            json:
              - application/json
              - text/json
            multipartForm: multipart/form-data
            pdf: application/pdf
            rss: application/rss+xml
            text: text/plain
            hal:
              - application/hal+json
              - application/hal+xml
            xml:
              - text/xml
              - application/xml
    urlmapping:
        cache:
            maxsize: 1000
    controllers:
        defaultScope: singleton
    converters:
        encoding: UTF-8
    views:
        default:
            codec: html
        gsp:
            encoding: UTF-8
            htmlcodec: xml
            codecs:
                expression: html
                scriptlet: html
                taglib: none
                staticparts: none

---
hibernate:
    cache:
        queries: false
        use_second_level_cache: false
        use_query_cache: false
dataSource:
    pooled: true
    jmxExport: true
    driverClassName: org.postgresql.Driver
    dialect: org.hibernate.dialect.PostgreSQLDialect
    type: com.zaxxer.hikari.HikariDataSource
    username: dict_ap
    password: 'LF2.net'
    logSql: false
    formatSql: true

environments:
    development:
        dataSource:
            dbCreate: none
            url: jdbc:postgresql://127.0.0.1:5432/ironman_dict_db
    test:
        dataSource:
            dbCreate: none
            url: jdbc:postgresql://127.0.0.1:5432/ironman_dict_db
    production:
        dataSource:
            dbCreate: none
            url: jdbc:postgresql://127.0.0.1:5432/ironman_dict_db
            properties:
                jmxEnabled: true
                initialSize: 5
                maxActive: 50
                minIdle: 5
                maxIdle: 25
                maxWait: 10000
                maxAge: 600000
                timeBetweenEvictionRunsMillis: 5000
                minEvictableIdleTimeMillis: 60000
                validationQuery: SELECT 1
                validationQueryTimeout: 3
                validationInterval: 15000
                testOnBorrow: true
                testWhileIdle: true
                testOnReturn: false
                jdbcInterceptors: ConnectionState
                defaultTransactionIsolation: 2 # TRANSACTION_READ_COMMITTED

grails-app/conf/application.yml 主要是專案的參數文件配置。

在 grails 框架中有三個預設環境,方便在不同環境中切換:

  • development: 開發環境
  • test: 測試環境
  • production: 生產環境

development 因為有配置 spring-boot-devtools ,所以在更動程式原始碼時,會啟用熱部署。

另外如果有第四種以上的環境需要特別部署,可以自行命名,範例如下:

  • grails-app/conf/application.yml
...
environments:
    test:
        dataSource:
            dbCreate: none
            url: jdbc:postgresql://127.0.0.1:5432/ironman_dict_db
    example:
        dataSource:
            dbCreate: none
            url: jdbc:postgresql://127.0.0.1:5432/ironman_dict_db
...

在執行,時需要加參數指定環境: -Dgrails.env

-Dgrails.env=example

不同環境的log配置

grails log 預設是 grails-app/conf/logback.xml,有需求可以另外新增。以下是針對不同環境處理的文件:

  • 預設: grails-app/conf/logback.xml
  • 測試環境: grails-app/conf/logback-test.xml
  • 開發環境: grails-app/conf/logback-development.xml

相對應的文件描述如下

  • grails-app/conf/application.yml
...
environments:
    development:
        logging:
            config: grails-app/conf/logback-development.xml
    test:
        logging:
            config: "${catalina.base}/webapps/ironman-dict/WEB-INF/classes/logback-test.xml"
...
  • grails-app/conf/logback.xml
<?xml version="1.0" encoding="UTF-8"?>
<configuration>

    <conversionRule conversionWord="clr" converterClass="org.springframework.boot.logging.logback.ColorConverter" />
    <conversionRule conversionWord="wex" converterClass="org.springframework.boot.logging.logback.WhitespaceThrowableProxyConverter" />

    <appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
        <encoder>
            <charset>UTF-8</charset>
            <pattern>%clr(%d{yyyy-MM-dd HH:mm:ss.SSS}){faint} %clr(%5p) %clr(---){faint} %clr([%15.15t]){faint} %clr(%-40.40logger{39}){cyan} %clr(:){faint} %m%n%wex</pattern>
        </encoder>
    </appender>

    <root level="error">
        <appender-ref ref="STDOUT" />
    </root>
</configuration>
  • grails-app/conf/logback-test.xml, grails-app/conf/logback-development.xml
<?xml version="1.0" encoding="UTF-8"?>
<configuration>

    <conversionRule conversionWord="clr" converterClass="org.springframework.boot.logging.logback.ColorConverter" />
    <conversionRule conversionWord="wex" converterClass="org.springframework.boot.logging.logback.WhitespaceThrowableProxyConverter" />

    <appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
        <encoder>
            <charset>UTF-8</charset>
            <pattern>%clr(%d{yyyy-MM-dd HH:mm:ss.SSS}){faint} %clr(%5p) %clr(---){faint} %clr([%15.15t]){faint} %clr(%-40.40logger{39}){cyan} %clr(:){faint} %m%n%wex</pattern>
        </encoder>
    </appender>

    <root level="info">
        <appender-ref ref="STDOUT" />
    </root>
</configuration>