blob: 91c3322876c1c7c48358288fc8cc323b6cfc4858 [file]
# frozen_string_literal: true
#
# Licensed to the Apache Software Foundation (ASF) under one or more
# contributor license agreements. See the NOTICE file distributed with
# this work for additional information regarding copyright ownership.
# The ASF licenses this file to You under the Apache License, Version 2.0
# (the "License"); you may not use this file except in compliance with
# the License. You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
#
# MySQL source definition generator class.
class MySQL
class << self
def connector_name
'flink-cdc-pipeline-connector-mysql'
end
def prepend_to_docker_compose_yaml(docker_compose_yaml)
docker_compose_yaml['services']['mysql'] = {
'image' => 'mysql:8.0',
'hostname' => 'mysql',
'environment' => {
'MYSQL_ALLOW_EMPTY_PASSWORD' => true,
'MYSQL_DATABASE' => 'cdcup'
},
'ports' => ['3306'],
'volumes' => ["#{CDC_DATA_VOLUME}:/data"]
}
end
def prepend_to_pipeline_yaml(pipeline_yaml)
pipeline_yaml['source'] = {
'type' => 'mysql',
'hostname' => 'mysql',
'port' => 3306,
'username' => 'root',
'password' => '',
'tables' => '\.*.\.*',
'server-id' => '5400-6400',
'server-time-zone' => 'UTC'
}
end
end
end