Skip to content

kusumotolab/kGenProg-exp

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

47 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

ここは

APRの実験スクリプト集.

APR実験における下記の雑多な作業をスクリプトとしてまとめた.

  • D4Jのクローンとビルド
  • KGPの〃
  • Astorの〃
  • KGP/Astorの実行

複数のDockerコンテナ上での実行を想定しているが,単一ホスト上でももちろん使える.

  • run.sh: docker実験コンテナの立ち上げスクリプト.
  • util.sh: メインスクリプト.先の雑多な作業(D4JのクローンとかAPRツールの実行)等まとめてる.
  • parse.py: APRツールの出力結果のパーサ.util.sh から利用してるので意識しなくても良い.

使い方

永続データ用のディレクトリ作成(10Gくらい使うので注意)

$ sudo mkdir -p /opt/apr-data

クローン

$ git clone git@github.com:kusumotolab/kGenProg-exp.git kgp-exp
$ cd kgp-exp

docker起動

$ bash run.sh apr

docker上でビルド

root@360a1f066293:~# source util.sh;
root@360a1f066293:~# build kgp
root@360a1f066293:~# build astor
root@360a1f066293:~# build d4j
root@360a1f066293:~# checkout math $(seq 1 106)

各種APR実行

root@360a1f066293:~# run math 85 kgp 1
root@360a1f066293:~# run math 73 genp 1

aws

ベース作成

sudo yum update -y
sudo yum install -y git
sudo yum install -y tmux
sudo amazon-linux-extras install docker -y
sudo service docker start

NVMeストレージのマウント

sudo mkfs -t ext4 /dev/nvme1n1
sudo mkdir /opt/apr-data
sudo mount /dev/nvme1n1 /opt/apr-data

dockerのパーミッション

sudo usermod -a -G docker ec2-user
exit

再ログイン

ssh ec2-user@...

astorのためのタイムゾーン設定

sudo timedatectl set-timezone Asia/Tokyo

dockerの設定

mkdir -p ~/.docker
echo '{"detachKeys": "ctrl-q"}' > ~/.docker/config.json

マシン固有の実験設定

echo 'export APR=astor'  >> ~/.bashrc
echo 'export SEED=1' >> ~/.bashrc
echo 'PS1="\e[37m\e[41m[aws $APR-$SEED]\e[0m\]$ "' >> ~/.bashrc
source ~/.bashrc

tmuxの設定

echo 'set -g prefix C-u' > ~/.tmux.conf

aprの実験準備

git clone https://github.com/kusumotolab/kGenProg-exp apr-exp
cd apr-exp
tmux
./run.sh

docker上で準備

# source util.sh ;
# build kgp; build astor; build d4j; checkout math $(seq 1 104);

実験実行

# source util.sh ;
# for i in {1..104}; do run math $i; done

細かいメモ

awsインスタンスのip

genp=(
    13.230.213.7
    13.230.160.85
    18.179.207.88
    13.231.119.253
    13.231.97.56
    13.231.157.145
    54.238.109.252
    54.178.17.35
    13.114.16.117
    13.115.43.0
    )
kgp=(
    52.194.236.208
    54.238.203.4
    13.112.136.252
    18.182.39.76
    13.115.253.105
    54.249.63.120
    52.68.33.92
    52.194.236.124
    54.64.0.228
    54.199.204.111
    )

実験結果の取り出し

$ /d/apr-exp/out/
$ for m in ${genp[@]}; do scp -C -i ~/.ssh/apr.pem ec2-user@$m:/opt/apr-data/out/* out-genp/; done
$ for m in ${kgp[@]};  do scp -C -i ~/.ssh/apr.pem ec2-user@$m:/opt/apr-data/out/* out-kgp; done

javaプロセスkill

ps -aux | grep java | grep apr-data | awk '{print $2}' | xargs sudo kill

全VMのapr実行をkill

for m in ${genp[@]}; do ssh -i ~/.ssh/apr.pem ec2-user@$m 'ps aux | grep java | grep apr-data | awk '\''{print $2}'\'' | xargs sudo kill ' ; done

docker kill all

docker kill $(docker ps -q)

前の実験結果クリア

sudo rm -rf /opt/apr-data/out/

(find /opt/apr-data/out/ -type f | sort | while read line do printf "$(basename $line) " cat $line | grep '^real' done ) | tee /tmp/x

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published