DolphinScheduler Upgrade

Prepare

Backup Previous Version’s Files and Database

To prevent data loss by some miss-operation, it is recommended to back up data before upgrading. The backup way according to your environment.

Download the Latest Version Installation Package

Download the latest binary distribute package from download and then put it in the different directory where current service running. And all below command is running in this directory.

Upgrade

Stop All Services of DolphinScheduler

Stop all services of dolphinscheduler according to your deployment method. If you deploy your dolphinscheduler according to cluster deployment, you can stop all services by command sh ./script/stop-all.sh.

Upgrade Database

Change configuration in ./bin/env/dolphinscheduler_env.sh ({user} and {password} are changed to your database username and password), and then run the upgrade script.

Using MySQL as an example, change the value if you use other databases. Please manually download the mysql-connector-java driver jar jar package and add it to the ./tools/libs directory, then change ./bin/ env/dolphinscheduler_env.sh file

  1. ```shell
  2. export DATABASE=${DATABASE:-mysql}
  3. export SPRING_PROFILES_ACTIVE=${DATABASE}
  4. export SPRING_DATASOURCE_URL="jdbc:mysql://127.0.0.1:3306/dolphinscheduler?useUnicode=true&characterEncoding=UTF-8&useSSL=false"
  5. export SPRING_DATASOURCE_USERNAME={user}
  6. export SPRING_DATASOURCE_PASSWORD={password}
  7. ```

Execute database upgrade script: sh ./tools/bin/upgrade-schema.sh

Upgrade Service

Change Configuration bin/env/install_config.conf

  • If you deploy with Pseudo-Cluster deployment, change it according to Pseudo-Cluster section “Modify Configuration”.
  • If you deploy with Cluster deployment, change it according to Cluster section “Modify Configuration”.

And them run command sh ./bin/start-all.sh to start all services.

Notice

Differences of worker group (before or after version 1.3.1 of dolphinscheduler)

The architecture of worker group is different between version before version 1.3.1 until version 2.0.0

  • Before version 1.3.1(include itself) worker group can be created through UI interface.
  • Since version 1.3.1 and before version 2.0.0, worker group can be created by modifying the worker configuration.

How Can I Do When I Upgrade from 1.3.1 to version before 2.0.0

  • Check the backup database, search records in table t_ds_worker_group table and mainly focus on three columns: id, name and IP.
idnameip_list
1service1192.168.xx.10
2service2192.168.xx.11,192.168.xx.12
  • Modify worker related configuration in bin/env/install_config.conf.

Assume bellow are the machine worker service to be deployed:

hostnameip
ds1192.168.xx.10
ds2192.168.xx.11
ds3192.168.xx.12

To keep worker group config consistent with the previous version, we need to modify workers configuration as below:

  1. #worker service is deployed on which machine, and also specify which worker group this worker belongs to.
  2. workers="ds1:service1,ds2:service2,ds3:service2"

The Worker Group has Been Enhanced in Version 1.3.2

Workers in 1.3.1 can only belong to one worker group, but after version 1.3.2 and before version 2.0.0 worker support more than one worker group.

  1. workers="ds1:service1,ds1:service2"

Recovery UI Create Worker Group after Version 2.0.0

After version 2.0.0, include itself, we are recovery function create worker group from web UI.