【OpenStack】Trunk Portをためす

Newtonで実装されたTrunk Portを試してみようかと。
わかりやすくVyOSでやってみる。

・Parent Port作成
・このParent PortのMac Addressを指定してChild Portを作成する
という流れのよう。

実際にやってみる。

<事前準備>
neutron.conf内のservice_pluginsにtrunkを追加。

# The service plugins Neutron will use (list value)
service_plugins=router,metering,firewall,trunk

neutronサービス再起動

# openstack-service restart neutron

<ネットワーク準備>

$ openstack network list
+--------------------------------------+----------------+--------------------------------------+
| ID | Name | Subnets |
+--------------------------------------+----------------+--------------------------------------+
| 9911d560-cd64-41d9-aac2-f8637010b614 | 172.20.10.0/24 | de53ce0a-6604-46e7-a97c-f26323fc8823 |
| bae535af-298b-4987-be7f-9bb7bdab7afd | 172.20.30.0/24 | b026b305-2731-471b-b358-51693cbed255 |
| e0d4d1b6-b71f-4a51-98ec-96cb8d55d0e0 | 172.20.20.0/24 | 0697e15f-8595-4df3-8eec-324dfb6aa1a6 |
+--------------------------------------+----------------+--------------------------------------+

<親ポート作成>

openstack port  create --network 9911d560-cd64-41d9-aac2-f8637010b614 parent0

<子ポート作成>

parent_mac="$( openstack port show parent0 | awk '/ mac_address / { print $4 }' )"
openstack port create --network e0d4d1b6-b71f-4a51-98ec-96cb8d55d0e0 --mac-address "$parent_mac" childport1
openstack port create --network bae535af-298b-4987-be7f-9bb7bdab7afd --mac-address "$parent_mac" childport2

<Trunkポート作成>

openstack network trunk create --parent-port parent0 --subport port=childport1,segmentation-type=vlan,segmentation-id=110 trunk0
openstack network trunk set --subport port=childport2,segmentation-type=vlan,segmentation-id=120 trunk0

<Trunkポート確認>

openstack network trunk show trunk0
+-----------------+-------------------------------------------------------------------------------------------------+
| Field | Value |
+-----------------+-------------------------------------------------------------------------------------------------+
| admin_state_up | UP |
| created_at | 2016-11-22T05:21:34Z |
| description | |
| id | b1555b22-fdbe-42c1-bd0f-eced582451c1 |
| name | trunk0 |
| port_id | 9d0240c6-338d-4790-b806-589434371f81 |
| revision_number | 2 |
| status | DOWN |
| sub_ports | port_id='3e3f9ddf-4432-4952-8e2f-706dec3b2e14', segmentation_id='110', segmentation_type='vlan' |
| | port_id='d90a11ae-98f8-4484-b6ed-1a9ffc5acb10', segmentation_id='120', segmentation_type='vlan' |
| tenant_id | 75680dae0c7b4e6296a53543687a8b6a |
| updated_at | 2016-11-22T05:22:51Z |
+-----------------+-------------------------------------------------------------------------------------------------+

<インスタンス作成>

openstack server create --flavor 3 --image 17074b09-66da-4fcc-b4ee-d6522191d4a6 --nic port-id=9d0240c6-338d-4790-b806-589434371f81 --security-group 0db30ac7-e1de-4ea2-96b2-a5f4a68cd57f VyOS_Trunk

<VyOS設定>

set interface ethernet eth0 address 172.20.10.10/24
set interface ethernet eth0 vif 110 address 172.20.20.8/24
set interface ethernet eth0 vir 120 address 172.20.30.2/24

これでPing通ったので完成かな。

【OpenStack】Security GroupのPermit Any

PackStackのMitakaでバグがあってProtocol Anyの設定ができなかったヤツが, Newtonで解消されていた。

Protocol番号で「-1」だったのが「0」に変わっていた。

なんかあったのかな。マイナス判定で処理がめんどくさかったとか,そもそもプロトコル番号は1からだからマイナスなんて使わずに0からでいいじゃん的なサムシングが。

【Cisco】ファイル共有のスループットが上がらない

この前,ファイル共有のスループットが上がらないからインタフェースの設定を変えたのだが,どうにも100Mbps以上スループットが出ない。

ホストマシン上もインタフェースは1Gでアップしているし,他に何か調整余地あるかなと調べてみた。
以下2パターンでは状況は変わらず。
・ PC → ファイルサーバ(インスタンス上)
・ PC → ファイルサーバ(ホストマシン)
ということはサーバ側の問題ではないなと。

C841MでNATの制御が引っかかってスループット上がってないんじゃ?なんておもってログインしようとしたら,ファイルコピー中はSSHの応答が無い。CPU100%張り付いていた・・・。

オマエか。原因は。

PCをファイルサーバと同一セグメントにうつしてためしたところ,先の2パターンどちらも800Mbps以上出ていた。

状況証拠から結論が出た。

・C841Mではルーティング処理は約100Mbpsが限界値。
・L2処理は800Mbps以上は出る。というか,前の検証結果に準ずるのだろう。

【OpenStack】FloatingIPが割り当てられないとき(ポートがありません状態)のメモ

なんかいつもググッて「あぁーそういえば!」となっているのでメモ。

・症状
インスタンスにFloating IPを割り当てようとして「ポートがありません」って表示されて対となるポートを選択できない時。

・処置
ダッシュボード上にて,

  • プロジェクト → ネットワーク → ルータ → ルータを選択
  • 右上にある「ゲートウェイの設定」ボタンをクリックして外部ネットワークを選択

以上。

【OpenStack】バージョンアップメモ

今回壊れたことで多少なりアップグレードするときにやることがわかったのでメモ。

バージョン上げた後は利用しているサービスのDB Syncをやっておく必要がある。

  • nova-manage db sync
  • neutron-db-manage
  • cinder-manage db sync
  • keystone-manage db_sync
  • 等など。
    まぁ結局今回失敗していたと思っていたのは,BIOSをアップデートしてIntelのVirtualizationがOFFになっていたことが一番大きかったというね・・・。
    # “kvm disabled by bios”というメッセージに気が付かなかった・・・

    【OpenStack】yum update したらダメになった・・・ orz

    先週末, yum updateした後からインスタンスが起動しなくなった。

    Cinder bootができず,しゃーないからスナップショットからバックアップをとりPackStack入れ直そうとおもっても,それも出来ず。

    あれこれやっていたら本格的にダメになり,いっそnewtonにアップグレードしてみたが,それでもダメ。

    DB SyncしてHorizonでちゃんと見れるが,アップグレード前と同じでインスタンスが起動しない。
    新規インスタンス作成もダメ。osloあたりでエラーメッセージが出ているのだが原因がわからずじまいで結局キレイに入れ直すことにした。

    が,ここでlvmのボリュームが消えずでまたこまった。
    lvchange -an からのlvremove -f でやってもダメ。

    レスキューモードで起動して無事消えました。

    さて,こっからまた作り直すかね・・・。

    VyOSの登録(別の方法)

    まえ,ESXでディスクイメージ作ってから登録したけど,ダッシュボードの操作やる方法をメモ。

    手順は以下の通り。

    1. VyOSのisoをイメージに登録してインスタンス起動
    2. 1GくらいのCinder ボリュームをアタッチする
    3. install image でそのボリュームにインストールする
    4. Cinderボリュームデタッチ
    5. そのボリュームをイメージへアップロード
    これでまぁいける。イメージフォーマットがrawのままだけど,いやならqumeとかで変換かければいいのかなとも思ったけどダメでした。
    qcow2じゃないよとエラーが出てこのイメージからは起動できない。
    はて・・・。

    【失敗】
    ・イメージダウンロード
    > glance image-download –file ./vyos_beta.raw –progress image_ID

    ・変換
    > qemu-img convert -f raw -O qcow2 ./vyos-beta.qcow2 vyos-beta.qcow2
    ・また登録
    glance image-create –name vyos-beta –visibility public
       –disk-format qcow2 –progress –file ./vyos-beta.qcow2
       –container-format bare
    qcow2にしたければ起動中のインスタンスのスナップショットをとって,それをダウンロード。
    で,またイメージアップロードすればいける。
    ただ,この時,元となるインスタンスのフレーバが起動時の最小要件となるから注意。
    そもそもめんどくさい手順だからrawのままでいいや。

    てか,qemu-img変換はなんでダメなんだろう。

    【OpenStack】稼働中のインスタンスでOpenStackコマンド

    毎度毎度コントローラーにログインするのもあれなので,インスタンスとして動いていてメインで使っているCentOSでOpenStackコマンドを叩くようにするメモ。

    参考サイト

    How to Install Pip on CentOS 7
    Install the OpenStack command-line clients

    ■ PIP入れる準備

    1. EPEL リポジトリ登録

    # rpm -iUvh https://dl.fedoraproject.org/pub/epel/7/x86_64/e/epel-release-7-8.noarch.rpm

    2. gccインストール
    # yum install gcc

    3. setuptoolsインストール
    # wget https://bootstrap.pypa.io/ez_setup.py -O – | sudo python

    4. pipインストール
    # yum install python-devel python-pip

    ■ OpenStackクライアントインストール

    # pip install python-openstackclient
    # pip install python-neutronclient (何故かneutronコマンドだけ入っていなかった)

    以上。

    これで基本こっちでいじればよくなった。
    ホスト側にあまり領域割かなかったから,イメージ登録とか楽になったわ。