2017年3月9日木曜日

Cisco NexusスイッチにおいてLACPでLAGを組む際のTips


データセンター向けスイッチのCisco Nexusスイッチシリーズ。
標準化されているリンクアグリケーション方式として、LACPを採用する場合、以下の仕様があるので注意。

LAGのチャネルから外れたリンクはIndividual状態となり、通信が可能となる。
Down状態から復旧した際に、LinkUP後~チャネルメンバーに参加してLAGを構成するまでの間、
一次的に、Loop構成になる。
Loop構成になると予期せぬ事象や、通信断が発生するため、以下の設定が必要。

Port-channelのinterfaceに対して
# lacp suspend-individual


上記の設定により、Port-Channelから外れたLinkはIndividual状態ではなく、suspend状態になる。
suspend状態はトラフィックの転送を不可の状態にし、Loop構成となることを防ぐ。
LinkUpと同時にLAGのメンバーに参加する。

Nexusシリーズの最近のOSだとほぼデフォルト実装。
EOSLレベルの昔のOSだと機能自体が無かったりするので、要注意。

デフォルト実装しているスイッチは、show run上では表示されない為、show run all等で確認する。

2017年3月8日水曜日

Laravel 5.4+MariaDBでログイン実装

過去の記事でLaravel環境のセットアップをしました(参照: http://kusanokai.blogspot.jp/2017/03/laradocklaravel_5.html)。

今回は、Laravelを用いたログインの実装について進めたいと思います。

[環境]
  • PHP 7.0.9
  • Laravel 5.4.15
  • MariaDB 10.1.21

[手順]
  1. 新規Laravelプロジェクトの作成(「logintest」という名前で作成しています)
  2. $ composer create-project laravel/laravel logintest

  3. DBの準備
  4. 使用するDBについて準備しておきます。
    laradockでデフォルトで環境構築した場合は、rootユーザ(パスワード:root)、
    もしくは、homestead(パスワード:secret)が使えます。
    laradockでmariadbを構築した場合は、まずmariadbコンテナに入ります。
    $ docker exec -it laradock_mariadb_1 /bin/bash
    mariadbへログイン。
    # mysql -h localhost -uroot -proot
    ログイン後、適当にDBを作成します。
    MariaDB [(none)]> CREATE DATABASE logintest;

  5. LaravelプロジェクトのDB設定
  6. Laravelプロジェクト、.envファイルのDB設定を変更しておきます。
    DB_CONNECTION=mysql
    DB_HOST=mariadb
    DB_PORT=3306
    DB_DATABASE=logintest
    DB_USERNAME=root
    DB_PASSWORD=root
    
    laradockで環境を作った場合は、DB_HOSTをmariadbにしておきます。
    DB_USERNAMEとDB_PASSWORDは2で使用したユーザ/パスワードを使用。

  7. migrateファイルの確認
  8. Laravelでは、新しくプロジェクトを作成した時点でユーザ用のmigrateファイルができています。

    ・./database/migrations/2014_10_12_000000_create_users_table.php
    <?php
    
    use Illuminate\Support\Facades\Schema;
    use Illuminate\Database\Schema\Blueprint;
    use Illuminate\Database\Migrations\Migration;
    
    class CreateUsersTable extends Migration
    {
        /**
         * Run the migrations.
         *
         * @return void
         */
        public function up()
        {
            Schema::create('users', function (Blueprint $table) {
                $table->increments('id');
                $table->string('name');
                $table->string('email')->unique();
                $table->string('password');
                $table->rememberToken();
                $table->timestamps();
            });
        }
    
        /**
         * Reverse the migrations.
         *
         * @return void
         */
        public function down()
        {
            Schema::dropIfExists('users');
        }
    }

    ・./database/migrations/2014_10_12_100000_create_password_resets_table.php
    <?php
    
    use Illuminate\Support\Facades\Schema;
    use Illuminate\Database\Schema\Blueprint;
    use Illuminate\Database\Migrations\Migration;
    
    class CreatePasswordResetsTable extends Migration
    {
        /**
         * Run the migrations.
         *
         * @return void
         */
        public function up()
        {
            Schema::create('password_resets', function (Blueprint $table) {
                $table->string('email')->index();
                $table->string('token')->index();
                $table->timestamp('created_at')->nullable();
            });
        }
    
        /**
         * Reverse the migrations.
         *
         * @return void
         */
        public function down()
        {
            Schema::dropIfExists('password_resets');
        }
    }
    ユーザやパスワードリセットの設定が入っています。
    とりあえず、このまま使うことにして、DBに反映させてみます。

  9. 試しにmigrate
  10. migrateファイルからmigrateを実行するには、下記のコマンドを実行します。
    (laradockで環境構築した場合は、workspaceコンテナから実行)
    # php artisan migrate
    結果、エラー。。
    [Illuminate\Database\QueryException]                                                         
      SQLSTATE[42000]: Syntax error or access violation: 1071 Specified key was too long; max key  
       length is 767 bytes (SQL: alter table `users` add unique `users_email_unique`(`email`))
    [PDOException]                                                                               
      SQLSTATE[42000]: Syntax error or access violation: 1071 Specified key was too long; max key  
       length is 767 bytes  
    Laravel5.4から絵文字対応でutf8mb4サポートしたことで、mariaDBか古いバージョンのMySQLで引っかかるらしいです。
    https://laravel-news.com/laravel-5-4-key-too-long-error

  11. AppServiceProvider.phpに設定追加
  12. 対策としては、「./app/Providers/AppServiceProvider.php」に設定を追加します。
    use Illuminate\Support\Facades\Schema;
    public function boot()
    {
        Schema::defaultStringLength(191);
    }
    (以下省略)
  13. 再度migrate
  14. いけるはず。

  15. Laravelのmake:auth機能でログイン機能の作成
  16. Laravel 5.2からはmake:authってのが使えるようなので、それ使います。
    (laradockで環境構築した場合は、workspaceコンテナから実行)
    # php artisan make:auth
    Authentication scaffolding generated successfully.

  17. Routeの確認
  18. なにやらいっぱいRouteができてるのが確認できます。
    # php artisan route:list
    +--------+----------+------------------------+------------------+------------------------------------------------------------------------+--------------+
    | Domain | Method   | URI                    | Name             | Action                                                                 | Middleware   |
    +--------+----------+------------------------+------------------+------------------------------------------------------------------------+--------------+
    |        | GET|HEAD | /                      |                  | Closure                                                                | web          |
    |        | GET|HEAD | api/user               |                  | Closure                                                                | api,auth:api |
    |        | GET|HEAD | home                   |                  | App\Http\Controllers\HomeController@index                              | web,auth     |
    |        | GET|HEAD | login                  | login            | App\Http\Controllers\Auth\LoginController@showLoginForm                | web,guest    |
    |        | POST     | login                  |                  | App\Http\Controllers\Auth\LoginController@login                        | web,guest    |
    |        | POST     | logout                 | logout           | App\Http\Controllers\Auth\LoginController@logout                       | web          |
    |        | POST     | password/email         | password.email   | App\Http\Controllers\Auth\ForgotPasswordController@sendResetLinkEmail  | web,guest    |
    |        | GET|HEAD | password/reset         | password.request | App\Http\Controllers\Auth\ForgotPasswordController@showLinkRequestForm | web,guest    |
    |        | POST     | password/reset         |                  | App\Http\Controllers\Auth\ResetPasswordController@reset                | web,guest    |
    |        | GET|HEAD | password/reset/{token} | password.reset   | App\Http\Controllers\Auth\ResetPasswordController@showResetForm        | web,guest    |
    |        | GET|HEAD | register               | register         | App\Http\Controllers\Auth\RegisterController@showRegistrationForm      | web,guest    |
    |        | POST     | register               |                  | App\Http\Controllers\Auth\RegisterController@register                  | web,guest    |
    +--------+----------+------------------------+------------------+------------------------------------------------------------------------+--------------+
    実はこれでできています。

  19. 試しにログイン
  20. http://localhost/registerへアクセスすると・・・、ユーザ作成が可能です。



    ログイン画面に行って(http://localhost/login)、ログインID/パスワードを入力。



    ログインできることが確認できます。


ほぼ、コードを書かずにユーザ登録、ログイン、パスワードリセットができてしまいました・・。
とても便利ですね。

最近だと、クライアントサイドはJavascriptに任せて、サーバ側はAPIを提供するのみ、となっているパターンも多いので、次回はAPIの使用を検討してみたいと思います。

2017年3月5日日曜日

LaradockでLaravel開発環境を整える

とある件で、Laravelを使った開発を行う機会があったので、開発環境を整備しました。
一応、OSX(Sierra)及びWindows 10 Proで検証済です。

[前提条件]
  • git導入済
  • Docker導入済
  • ネット環境あり
この辺りは適当に・・・。

 [手順]
  1. 適当に作業用のフォルダを作成して移動。
  2. $ mkdir work
    $ cd work
    

  3. gitでlaradockをcloneして移動。
  4. $ git clone https://github.com/laradock/laradock
    $ cd laradock
    

  5. docker-composeでとりあえず、workspaceを立ち上げる。
  6. $ docker-compose up -d workspace
    
    workspaceってなんじゃい、って感じですが、Composerで何かをインストールしたり、Laravelコマンドを実行したりする場合は、workspace環境から実行するようです。

  7. workspaceの確認。
  8. $ docker-compose ps
             Name                Command      State           Ports
    -----------------------------------------------------------------------
    laradock_applications_1   /true           Exit 0
    laradock_workspace_1      /sbin/my_init   Up       0.0.0.0:2222->22/tcp
    
    問題なく立ち上がってそうです。

  9. workspaceへ入ってみる。
  10. $ docker exec -it laradock_workspace_1 /bin/bash
    root@1258840ba9fe:/var/www#
    
    「-i」が対話型(interactive)、「-t」が擬似ttyに接続する、というオプションのようですが、雰囲気sshでログインするような感じです。
    また、workspaceコンテナの「/var/www」のフォルダと1で作成した作業用のフォルダがリンクしていることがわかります。

  11. workspaceからlaravelプロジェクトを作成してみる。プロジェクト名は適当にlaraveltestを指定しています。
  12. root@1258840ba9fe:/var/www# composer create-project laravel/laravel laraveltest
    
    workspaceコンテナの「/var/www」のフォルダと作業用のフォルダがリンクされているため、プロジェクトを作ると、1で作成した作業用フォルダからも参照できることが確認できます。
    ソースコード書くときは、普通にホストWindowsかホストMac側からプロジェクト内のソースコードを変更すれば、適用される感じ、ということですね。

  13. 一旦workspaceから抜け、docker-composeを停止。
  14. root@1258840ba9fe:/var/www# exit
    $ docker-compose stop
    

  15. docker-compose.ymlの設定を一部変更する。
  16. ・docker-compose.yml(変更後)
    version: '2'
    
    services:
    
    ### Applications Code Container #############################
    
        applications:
            image: tianon/true
            volumes:
                - ../laraveltest:/var/www
    
    (以下略)
    
    「- ../:/var/www」あたりの所を、「- ../laraveltest:/var/www」に変更します。
    (作成したプロジェクト名に応じて適宜変更してください。)

  17. Apache2およびmariadbを指定して、docker-composeの起動
  18. docker-compose up -d apache2 mariadb
    
    そこそこ時間かかります。
    LaradockにはApache2やmariadb以外にも、nginxであったりMySQL等色々なイメージが含まれているので、必要に応じて指定してください。

  19. 接続確認として「http://localhost/」にアクセスしてみる。


とりあず、これでLaravelで開発できる環境ができました。
Dockerはあまり使ったことがなかったのですが、サクッと環境を共有できるのは良さそうです。