demo siteを作成
compute engineを立ち上げる
省略
compute engineを設定
SSHをクリックして、以下をまず実行
sudo apt update
sudo apt install apache2 php libapache2-mod-php -y
sudo apt install postgresql postgresql-contrib -y
JavaScriptsudo apt-get install php-pgsql
JavaScriptsudo systemctl restart apache2
JavaScriptsql databaseを設定
sudo -u postgres psql
JavaScriptdata:image/s3,"s3://crabby-images/f6cf7/f6cf76b190a11bbe2c6b3e975c770046b21daad2" alt=""
databaseとテーブルを作成
CREATE DATABASE myappdb;
SQLユーザーとパスワードを作成
CREATE USER gaozhan WITH PASSWORD 'postgres_pwd';
SQLユーザーに権限を付与する
GRANT ALL PRIVILEGES ON DATABASE myappdb TO gaozhan;
GRANT ALL PRIVILEGES ON TABLE users TO gaozhan;
GRANT USAGE, SELECT, UPDATE ON public.users_id_seq TO gaozhan;
ALTER ROLE gaozhan WITH REPLICATION;
GRANT SELECT ON ALL TABLES IN SCHEMA public TO gaozhan;
GRANT USAGE ON SCHEMA public TO gaozhan;
ALTER DEFAULT PRIVILEGES IN SCHEMA public
GRANT SELECT ON TABLES TO gaozhan;
SQL作成したDBに遷移する
\\c myappdb
ShellScriptパブリケーションを作成
CREATE PUBLICATION datastream_publication_all_tables FOR ALL TABLES;
SQLリプリケーションを作成
SELECT PG_CREATE_LOGICAL_REPLICATION_SLOT('datastream_replication_slot_myappab', 'pgoutput');
SQLテーブルを作成する
CREATE TABLE users (
id SERIAL PRIMARY KEY,
name VARCHAR(100),
age INT,
gender VARCHAR(50),
company VARCHAR(100)
);
SQLデータベースを閉じる
\\q
SQLデータベースを再起動
sudo systemctl restart postgresql
ShellScriptweb siteを作成
front
以下のコードを使う
sudo nano index.html
ShellScriptindex.html
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Simple Data Collection Form</title>
</head>
<body>
<form action="form-handler.php" method="post">
<label for="name">Name:</label>
<input type="text" id="name" name="name"><br>
<label for="age">Age:</label>
<input type="number" id="age" name="age"><br>
<label for="gender">Gender:</label>
<select id="gender" name="gender">
<option value="male">Male</option>
<option value="female">Female</option>
<option value="other">Other</option>
</select><br>
<label for="company">Company:</label>
<input type="text" id="company" name="company"><br>
<input type="submit" value="Submit">
</form>
</body>
</html>
JavaScriptsudo touch form-handler.php
sudo nano form-handler.php
ShellScriptbackend
以下をコピーする
form-handler.php
<?php
// Display all errors, good for development
ini_set('display_errors', 1);
error_reporting(E_ALL);
// Database credentials
$host = "localhost";
$dbname = "myappdb";
$user = "gaozhan";
$password = "postgres_pwd";
// Connect to the database
try {
$conn = new PDO("pgsql:host=$host;dbname=$dbname", $user, $password, [
PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION
]);
} catch (PDOException $e) {
die("Could not connect to the database $dbname :" . $e->getMessage());
}
// Only proceed if the form data is being posted
if ($_SERVER["REQUEST_METHOD"] == "POST") {
$name = $_POST['name'];
$age = $_POST['age'];
$gender = $_POST['gender'];
$company = $_POST['company'];
// Prepare the SQL statement
$stmt = $conn->prepare("INSERT INTO users (name, age, gender, company) VALUES (:name, :age, :gender, :company)");
// Bind parameters
$stmt->bindParam(':name', $name);
$stmt->bindParam(':age', $age);
$stmt->bindParam(':gender', $gender);
$stmt->bindParam(':company', $company);
// Execute and check if the statement was successful
if ($stmt->execute()) {
// Redirect to a confirmation page or back to the form page with a success message
header('Location: success.html');
exit();
} else {
// Output error information
$errorInfo = $stmt->errorInfo();
die("Error entering data: " . $errorInfo[2]);
}
}
// Close the connection
$conn = null;
?>
JavaScriptthanks page
sudo touch success.html
sudo nano success.html
ShellScript以下をコピーする
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Form Submission Successful</title>
</head>
<body>
<p>Thank you for submitting the form. We have received your data.</p>
</body>
</html>
JavaScriptdatabaseにホワイトリストを追加する
sudo nano /etc/postgresql/13/main/pg_hba.conf
ShellScript以下のIPをホワイトリストに追加する
host myappdb gaozhan 34.72.28.29/32 md5
host myappdb gaozhan 34.67.234.134/32 md5
host myappdb gaozhan 34.67.6.157/32 md5
host myappdb gaozhan 34.72.239.218/32 md5
host myappdb gaozhan 34.71.242.81/32 md5
ShellScriptこちらでGCP各リージョンのIPを確認できる
https://cloud.google.com/datastream/docs/ip-allowlists-and-regions?hl=ja
共有を許可する
sudo nano /etc/postgresql/13/main/postgresql.conf
ShellScript以下のように修正
#------------------------------------------------------------------------------
# WRITE-AHEAD LOG
#------------------------------------------------------------------------------
# - Settings -
wal_level = logical # minimal, replica, or logical
# (change requires restart)
#------------------------------------------------------------------------------
# CONNECTIONS AND AUTHENTICATION
#------------------------------------------------------------------------------
# - Connection Settings -
listen_addresses = '*' # what IP address(es) to listen on;
# comma-separated list of addresses;
# defaults to 'localhost'; use '*' for all
# (change requires restart)
ShellScriptdatastreamを設定する
data:image/s3,"s3://crabby-images/3f3b1/3f3b1e0da56df5c84f6b28e18e347e2fdc7c6763" alt="".png)
重要 接続テスト
data:image/s3,"s3://crabby-images/97fc3/97fc3e6a5d2a7b68916d56c66ff1f81a1a677fc5" alt="Untitled".png)
- 名前とIDは任意
- リージョンはus-central1
- ipはCompute engineの外部IP
- ポート:5432
- ユーザー名、Password、DB:上で設定したDBの情報
ソースの構成:先ほど作った情報で
data:image/s3,"s3://crabby-images/3389a/3389a327bec7b1ce65b027d10374010a96c536e6" alt="Untitled".png)
宛先の定義:任意の名前
data:image/s3,"s3://crabby-images/434a4/434a4b03ad517aed463d5d03fed536162e59ebf8" alt="Untitled".png)
宛先の構成:そのまま
確認と作成
接続テストをして、問題なければ作成
data:image/s3,"s3://crabby-images/c9d10/c9d10070d5d6c4a9fc0ee007a470a7f0867e22a3" alt="Untitled".png)
開始をクリック
私はクリックしたので一時停止になっている。。。
data:image/s3,"s3://crabby-images/cdaef/cdaef6f1f2160024482e0e4a076ba143e79c5017" alt="Untitled".png)
bigqueryでストリーミングデータを確認できる
data:image/s3,"s3://crabby-images/25bd3/25bd3f34a1f999fad16d87c6a25a7bfd201be6cc" alt="Untitled".png)
更新のタイムラグ
データベースの更新がDatastreamに同期されるのは、大体30秒ぐらい
data:image/s3,"s3://crabby-images/95c1a/95c1a5809fd8bbb6647f4f2e7ca38722dabebbe1" alt="Untitled".png)
Bigqueryに反映されるのは、これによるので、大体15分1回で最新データがBigqueryに同期される
data:image/s3,"s3://crabby-images/82a62/82a6224f35c110c1cfb976b59fcbd238a4c769b3" alt="Untitled".png)
これでデータをinsertできる
http://datamarketing-bank.com/
ここでデータ同期を確認できる