0
1

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 5 years have passed since last update.

新人エンジニアの時に知っておきたかったこと[sandbox環境編]

Last updated at Posted at 2018-08-04

はじめに

この記事は新人エンジニアの時に知っておきたかったことに含まれます。
他の記事は上記のリンクから遷移可能です。あわせてご覧ください。

sandbox環境

私がエンジニアとしてのキャリアを歩み始めたあの時、Windowsのノートパソコンを開いてプログラミングをしていました。
PHPのコードを動かしたいということで、XAMPPを触ってみたりしていました。
あの時感じたのは、PHPのコードを書くモチベーションが高まっているのに、準備するのに時間かかるなぁということです。
振り返ってみると、始めの頃につまづいていたのは、環境構築だったり、インストールだったりという思い出があります。
PHP書きたい、Redis触りたい、なんでもいいからとにかく触ってみたいという気持ちがあるはずです。
そこで、とりあえずPHPとかNodeとかをインストールしたsandbox環境を用意してみました。

hirokisan/sandbox

インストール済みの主なツール

PHP

$ php -v
PHP 7.0.30 (cli) (built: Apr 24 2018 21:28:23) ( NTS )
Copyright (c) 1997-2017 The PHP Group
Zend Engine v3.0.0, Copyright (c) 1998-2017 Zend Technologies

Composer

$ composer dump-autoload -V
Composer version 1.6.5 2018-05-04 11:44:59

Redis

redis-cli -v
redis-cli 3.2.10

MariaDB

mysql -uroot
>status
Server version:		5.5.56-MariaDB MariaDB Server

Node

$ node -v
v8.9.4

NPM

$ npm -v
5.6.0

Yarn

$ yarn -v
1.7.0

Git

$ git --version
git version 1.8.3.1

必要なもの

Docker For Mac

Docker For Macを使用します。

手順

Docker For Macを既にインストールしたものとして、sandbox環境をセットアップしていきます。

1. Docker For Macを起動する

アプリケーションからDocker.appを選び、起動します。

スクリーンショット 2018-07-27 23.51.24.png

2. ソースを用意する

まずはソースをダウンロードします。
$PATHはあなたの好きなディレクトリで置き換えてください。

$ cd $PATH
$ git clone https://github.com/hirokisan/sandbox.git

3. ssh接続用の鍵を生成する

以下のコマンドを実行します。
ただし、$PATH には sandbox ディレクトリへのパスを設定します。
~/Desktop/ 以下に sandbox を配置した場合、
$PATH の部分は Desktop に置き換えてください。

$ ssh-keygen -f ~/$PATH/sandbox/workspace/id_rsa

4. hostsファイルに変更を加える

$ sudo sh -c "echo 127.0.0.1 sandbox.local >> /etc/hosts"

5. SSH Configに変更を加える

以下のコマンドを実行します。

ただし、$PATH には sandbox ディレクトリへのパスを設定します。
~/Desktop/ 以下に sandbox を配置した場合、
$PATH の部分は Desktop に置き換えてください。

$ printf "\
Host sandbox.local
  HostName 127.0.0.1
  User sandbox
  Port 10080
  UserKnownHostsFile /dev/null
  StrictHostKeyChecking no
  LogLevel FATAL
  IdentityFile ~/$PATH/sandbox/workspace/id_rsa
" | cat >> ~/.ssh/config

6. コンテナ立ち上げ

$ docker-compose up -d --build

7. sshでコンテナにログインする

$ ssh sandbox.local

8. コンテナにログインして初期設定する

$ bash ~/init.sh

9. Dotfiles初期設定

Dotfilesに関しては必ずしも設定する必要はありません。
なので、Dockerfileでは設定箇所をコメントアウトしています。
使用したい方は、コメントアウトを解除してください。

コンテナにログイン後に以下のコマンドを実行します。

$ git clone -b sandbox-use https://github.com/hirokisan/dotfiles.git ~/dotfiles
$ bash ~/dotfiles/install.sh

ログインシェルの切り替えを反映させるため、コマンド実行後に一旦コンテナからログアウトして再度ログインします。
すると、zplug installが実行され、あらかじめ定義されているプラグインがインストールされます。
スクリーンショット 2018-07-27 23.38.07.png

Vimでファイルを開くと、定義されているプラグインのインストールが始まります。

2018-07-27 23_45_47.gif

試しにPHPプログラムを動かしてみましょう

vim quickrunでPHPプログラムを動かしてみます。
2018-07-27 22_56_35.gif

コマンドラインからPHPプログラムを動かしてみます。
2018-07-27 22_59_55.gif

試しにMariaDBを動かしてみましょう

2018-07-27 23_02_04.gif

試しにRedisを動かしてみましょう

vim quickrunでRedisと連携したPHPプログラムを動かしてみます。
2018-07-27 23_05_20.gif

補足

とりあえず、手軽にsandboxを作ることが今回の要件です。
1つのコンテナで複数のプロセスを起動するのは本来のコンテナの使い方ではないようですが、ご容赦ください。

まとめ

この記事では簡単にプログラムの動作確認をしたいときに使えるsandbox環境をご共有しました。
dockerやvagrant等を使うことで、手軽に動作確認用のsandbox環境を用意することができます。
ぜひ、お試しください。

0
1
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
0
1

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?