システムエンジニアリングでは、コミュニケーションはあらゆるプロジェクトで成功を収めるための重要な要素です。これは、開発のサイクル全体にとって重要だからです。要件の収集から、実行可能な最小限の製品の提供まで。
分散バージョン管理システム(Gitなどの業界標準)を使用して、開発者は小さなコードを送信し、それを中心に構築されたBitbucketなどのサービスと連携できます。 Bitbucketをホストすることは、PostgreSQLのように、ユーザーによって生成されたデータにデータベースが残っている場合に可能ですが、両方を統合するには、異なるマシンで実行するための追加の構成が必要です。
ローカルエリアネットワークは、ユーザーがどこにいるかに応じて、外部ネットワークに情報を公開することなく、プログラム間で情報を渡すことができます。
data:image/s3,"s3://crabby-images/62ae2/62ae28b1bc2eb5c359c02289a811bd84c5877763" alt=""
data:image/s3,"s3://crabby-images/7f599/7f599922e5f6a268bf870cb7b9ef2e39df30074a" alt=""
data:image/s3,"s3://crabby-images/45682/45682265aed286227244143595ce2160f2534eec" alt=""
これは非常に単純なプロセスであるため、言うことはあまりありません。 PostgreSQLは、Bitbucketの準備ができた新しいユーザーとデータベースでセットアップする必要があります。
PostgreSQL
# Part 1: Preparing the database. $ pg_lsclusters $ sudo systemctl -a | grep postgres $ sudo -u postgres psql -c "\du" -c "\l"
data:image/s3,"s3://crabby-images/fd983/fd983bccd25375923d58c4adb4335122b5e9ccac" alt=""
# Part 2: Creating a new user (role) and database. $ sudo -u postgres psql -c "create role thiago with createdb login password 'Th14g0_P4ssw0rd'" $ psql -d postgres -c "create database bitbucket_db" $ psql -d bitbucket_db -c "\du" -c "\l"
data:image/s3,"s3://crabby-images/831e4/831e4f3493c3af364f2032d83164ca620cc93acc" alt=""
# Part 3: Changing the cluster configuration (postgresql.conf). $ sudo -u postgres psql -c "show config_file" $ sudo cat /etc/postgresql/11/main/postgresql.conf | grep listen_addresses $ sudo sed -i "s|#listen_addresses = 'localhost'|listen_addresses = '\*'\t|" /etc/postgresql/11/main/postgresql.conf $ sudo cat /etc/postgresql/11/main/postgresql.conf | grep listen_addresses
data:image/s3,"s3://crabby-images/83bb6/83bb6f27caa9a8e7ce5a392b2204c66cc8821b03" alt=""
# Part 4: Changing the cluster configuration (pg_hba.conf). $ sudo wc -l /etc/postgresql/11/main/pg_hba.conf $ sudo tail -3 /etc/postgresql/11/main/pg_hba.conf $ sudo sed -i "$ a # Allow remote connections (listen_addresses = '*') with authentication" /etc/postgresql/11/main/pg_hba.conf $ sudo sed -i "$ a host\tall\t\tall\t\t192.168.0.0/16\t\tmd5" /etc/postgresql/11/main/pg_hba.conf $ sudo sed -i "$ a host\tall\t\tall\t\t::/0\t\t\tmd5" /etc/postgresql/11/main/pg_hba.conf $ sudo wc -l /etc/postgresql/11/main/pg_hba.conf $ sudo tail -3 /etc/postgresql/11/main/pg_hba.conf
data:image/s3,"s3://crabby-images/631f0/631f070759e8f50b230493b63010c96eb78f70bd" alt=""
# Part 5: Restarting the cluster. $ sudo -u postgres psql -c "show listen_addresses" $ ss -nlp | grep 5432 $ sudo systemctl restart [email protected] $ sudo -u postgres psql -c "show listen_addresses" $ ss -nlp | grep 5432
data:image/s3,"s3://crabby-images/3f673/3f6737c63f20674cb26f3ee10546b7a2302cf0d9" alt=""
# Part 6: Opening the door. $ sudo ufw status $ sudo ufw allow 5432/tcp $ sudo ufw status $ ip addr show
data:image/s3,"s3://crabby-images/d9f5a/d9f5a701bd36cae3d527e2b701ef92f46fee14dd" alt=""
# Part 7: Set a password for the superuser role. $ sudo -u postgres psql -c "\password"
data:image/s3,"s3://crabby-images/014b1/014b100fe1320c792131577d3dac1850fc41cae7" alt=""
# Part 1: Verifying if the earlier set up was correct. $ telnet 192.168.0.106 5432 # (Optional) Using psql. $ sudo -u postgres psql -h 192.168.0.106 -p 5432 -d bitbucket_db -U thiago -c "\conninfo"
data:image/s3,"s3://crabby-images/726ab/726abae9c485226364d5081a213a9c6f1164f517" alt=""
# Part 2: Extracting the Bitbucket Server. $ ls $ tar xzf atlassian-bitbucket-6.10.0 $ ls $ du -sh atlassian-bitbucket-6.10.0 $ tree -L 1 atlassian-bitbucket-6.10.0 $ tree -L 1 atlassian-bitbucket-6.10.0/bin
data:image/s3,"s3://crabby-images/c2229/c2229417eb90173cf26fd3a1520380f4b40fffd0" alt=""
# Part 3: Modifying the script (set-bitbucket-home.sh). $ mkdir bitbucket-home $ echo $(pwd)/bitbucket-home $ cat atlassian-bitbucket-6.10.0/bin/set-bitbucket-home.sh | grep BITBUCKET_HOME=$ $ sed -i 's|BITBUCKET_HOME=$|BITBUCKET_HOME=/home/thiago/Documents/severalnines.com/database-blog/bitbucket-home|' atlassian-bitbucket-6.10.0/bin/set-bitbucket-home.sh $ cat atlassian-bitbucket-6.10.0/bin/set-bitbucket-home.sh | grep BITBUCKET_HOME=/
data:image/s3,"s3://crabby-images/82638/826382a9c002e704baf484450a669e80537d39c4" alt=""
# Part 4: Modifying the script (set-jre-home.sh). $ readlink -f $(which java) $ cat atlassian-bitbucket-6.10.0/bin/set-jre-home.sh | grep JRE_HOME=$ $ sed -i 's|JRE_HOME=$|JRE_HOME=/usr/lib/jvm/java-11-openjdk-amd64|' atlassian-bitbucket-6.10.0/bin/set-jre-home.sh $ cat atlassian-bitbucket-6.10.0/bin/set-jre-home.sh | grep JRE_HOME=/
data:image/s3,"s3://crabby-images/aee38/aee384252d0bfaa4d80d79ecffe2de27a6962cca" alt=""
# Part 5: Checking the hardware. $ cat /proc/cpuinfo | grep processor | wc -l $ free -h
data:image/s3,"s3://crabby-images/bc89a/bc89aec424578c85f406c65ce4dd4ea1049b0282" alt=""
# Part 6: Running the Bitbucket Server with Elasticsearch. $ ./atlassian-bitbucket/bin/start-bitbucket.sh $ free -h
data:image/s3,"s3://crabby-images/e038d/e038da030e481f4d68297ea023f0742d71e53042" alt=""
# Part 7: Running the Bitbucket Server without Elasticsearch. $ ./atlassian-bitbucket/bin/start-bitbucket.sh --no-search $ free -h
data:image/s3,"s3://crabby-images/ee584/ee584ca2a22f5d47bb8c49771e5ff5c14ff22c91" alt=""
# Part 8: Quick look at BITBUCKET_HOME. $ du -sh bitbucket-home $ tree -L 1 bitbucket-home
data:image/s3,"s3://crabby-images/db0e5/db0e571486556db3d621c35f25d731706c645352" alt=""
PostgreSQLとBitbucketの統合
PostgreSQLとBitbucketを構成した後、それらの統合はブラウザー(http:// localhost:7990 /)を介して実行する必要があります。
data:image/s3,"s3://crabby-images/df0b0/df0b0facd818c6a34756413221405c9322742f40" alt=""
# Displaying tables $ psql -h 192.168.0.106 -d bitbucket_db -c "\dt"
data:image/s3,"s3://crabby-images/88493/884937e769681223b9c84d00dd8ae095bba0623c" alt=""
data:image/s3,"s3://crabby-images/30bea/30bea8e7f4b22e0ca77fa85cb22e3811ecd7212f" alt=""
# Displaying tables (again) $ psql -h 192.168.0.106 -d bitbucket_db -c "\dt"
data:image/s3,"s3://crabby-images/fd771/fd771a60e7e831ea890875457da01374ce818882" alt=""
# Verifying the connection pool. $ psql -h 192.168.0.106 -d bitbucket_db -c "select pid,usename,application_name,state from pg_stat_activity where datname = 'bitbucket_db'"
data:image/s3,"s3://crabby-images/5debf/5debf2d5623e849d60e20342d92efbed9a72084f" alt=""
ネットワークでDHCPを使用している場合は、ルーターでIPアドレスを静的に構成することをお勧めします。そうしないと、Bitbucketが後でPostgreSQLを見つけようとして失敗する可能性があります。
このブログのほとんどは、テキストエディターを開かずに構成ファイルを変更するために正規表現を使用していますが、デバッグ目的でWebブラウザーでも使用できます。エラーメッセージ「できませんでした」を検索してみてください。ディレクトリを「?:アクセスが拒否されました」に二重引用符で囲むか、その他の問題が発生した場合は、コンピュータ固有のパスをワイルドカード「?」に置き換えてください。