.NET Conf in Tokyo 2019に参加してきました #dotnetconf
- What’s New in .NET Core 3.0 and Visual Studio 2019 for .NET developers
- .NET の今と今後に思うこと (Tokyo Ver.)
- 資料
- Windows DNA?
- One ASP.NET
- .NET オープンソースの道のり
- .NET foundation
- .NET Application Models(.NET Core 3.0)
- .NET Framework の今後について
- Visual Studio App Center for .NET Core 3.0 Windows Apps
- Windows Forms とWPFのオープンソースモメンタム
- APS.NET Core 3.0 Blazor
- Programinng
- Machine Learnig
- ML.NET
- Introducing .NET 5
- .NET スケジュール
- まとめ
- .NET Core 3.0 + Windows 10 で WPF 開発
- Inside FastEnum
- C# 8.0 非同期ストリーム
- Unity Trackの資料
- 他の方の感想・まとめ
2019/10/27(日)に開催された .NET Conf in Tokyo 2019の参加レポートです。遅っ
危うく前日の10/26(土)に品川に行くところだった。
.NET関連は初めて参加した。
.NET Core 3.0だからLinux中心か?と思ってたぐらい.NETは疎い。
Visual Studio 2019と.NET Core 3.0が普通の組み合わせなのね。
What’s New in .NET Core 3.0 and Visual Studio 2019 for .NET developers
Steve Carroll
資料
.NET Growth Continues
スポンサー
.NET FoundationのコーポレートスポンサーにAWSが参加
Miscroservice
ASP.NET Core 3.0
- gRPC
- Woker Service
- WebAPI + Identity
C#8.0
- null許容参照型
- 非同期ストリーム
- 範囲アクセス
- パターン ベースな using
- readonly 関数メンバー?
- using ステートメントの改善
Xamarin
Blazor
ML.NET
.NET 5
.NET Framework、.NET Core、Xamarinと3つに別れていたランタイムとライブラリが.NETで一本化する
.NET Schedule
バージョン | リリース予定 | LTS |
---|---|---|
.NET Core 3.1 | Dec 2019 | LTS |
.NET 5.0 | Nov 2020 | |
.NET 6.0 | 2021 | LTS |
.NET 7.0 | 2022 | |
.NET 8.0 | 2023 | LTS |
.NET Core 3.1が2019/11から2019/12に延びたらしい。 2年ごとの偶数バージョンがLTSになるのね。
Visual Studio 2019 for .NET devs
- Visual StudioとVisual Sutdio Code で Live Share
- ソース画面の共有
- 定義元へのジャンプ
- co-editing
- co-debugging
Viusal StudioとVisual Studio CodeでLive Shareで共有。
将来Language Srever Protocolのように、エディタ、IDEで跨って共有できるようにプロトコルが できたら面白いんだけどな。
Code fixes and refactorings
変数を検索したに出てくるウインドウでread(参照)かwirte(更新)かがわかり、kindカラムでフィルターもできる。 Visual Studio 2019 リリース ノート より
正規表現もIntelliSenseのリファクタリングの対象
Visual Studio 2019に正規表現の補助機能が増えてた話Clrl + .
usingしなくても補完の候補にでるし、選択したらusingが補完される。
メソッドの引数のnullチェックを自動生成
いいようにリファクタリングしてくれる。 以下にアニメーション、動画があってわかりやすい。- Visual Studio で一番費用対効果の高いショートカット「Ctrl + .」
- Visual Studio 2019 Preview .NET Productivity
configure
.editorconfigをVisual Studio上から生成
タブとスペースの宗教戦争の抑止
Visual Studioのデモを生で見たの初めてだ。
動かしてるのを見るとそうやって使うのねと感心する。
.NET の今と今後に思うこと (Tokyo Ver.)
Akira Inoue (@chack411)
資料
Windows DNA?
https://www.itmedia.co.jp/help/howto/win/win2000/0007special/complus_vb/chap1/08.html
.NET Frameworkが出る2002年よりも前。com中心の世界。
One ASP.NET
コンパクトにプラがブルにOSに依存しないようにする流れ
.NET オープンソースの道のり
- 2008 ASP.NET MVC
- 2014 Apr. Roslyn
- 2014 Nov. .NET core
.NET foundation
- 今年はawsがコーポレートスポンサーとして参加
.NET Application Models(.NET Core 3.0)
- .NET Core クロスプラットフォーム Linux、Windows、Mac
- WPF、Win Formsが.NET Core 3.0で作れるようになった。 ただし、Windowsプラットフォームのみ。
.NET Framework の今後について
- .NET Framework 4.8が最後のメジャーバージョンとなる予定 マイナーバージョンは変わる可能性はある。
- サポートライフサイクルポリシーの変更はなし インストール先のWindows OSと同じライフサイクルポリシーと同じ
- .NET Coreが主流となってきた
- 既存は、.NET Frameworkベースはそのまま利用可能
- 新規開発の場合は.NET Coreを推奨
Visual Studio App Center for .NET Core 3.0 Windows Apps
WPF、Win Fromsなどデスクトップアプリの機能は停滞していた。 裏では、.NET Core側へ移行していた
App Center
App Centerで配布用のアプリの作成、配布できる 配布対象グループの人にメールが届き、使う人は、App Centerからダウンロードして、インストールできるWPF、Win Formsでcraashレポート、テレメトリーがとれるようになった。
実行環境、バージョンなどが取れるようになった
Windows Forms とWPFのオープンソースモメンタム
プルリクが増加、今まで見えなかったバグの見るかと対応の速さもOSS化もメリット
APS.NET Core 3.0 Blazor
ブレザー
- C#で作ったWebAssemblyをブラウザで動作させる
- JavaScript(Angular、React、Vue)を知らなくてもOK
- 全部C#で作れる
rezor構文
2種類
Programinng
アルゴリズムと入力から答えを求める
Machine Learnig
答えと入力からアルゴリズムを求める
ML.NET
- ML.NET Model Builder
- AutoMLである程度最適なアルゴリズムを検出してくれる
- 生成されたモデルもzip形式でアプリケーションに組み込まれる
- 例 感情分析
Introducing .NET 5
- 別れていた実装部分を統一
- .NET Core/Xamarionのアプリケーションモデルは全サポート
- .NET Frameworkからは.NET 5では含まれないアプリケーションモデルもある
.NET スケジュール
- .NET Core 3.1 Dec 2019
NovからDecにずれ込んでいる
まとめ
この10年はクラウド革新・・・今後は?
- .NET Frameworkは、Windowsしか動けない巨大なフレームワーク
- 細分化して、OSへの依存をなくしていったのが.NET Core。
技術を塩漬けするリスクと最新技術を使う意味
- 今使えるから塩漬けすると、5年後、10年後にアップデートすると大変
- 常に最新化するも大変だが、CI/CD/DevOpsの環境を整えて、最新化していく 最低でもLTS版でアップデートする 10年後も最新版を保っていく
.NETを使い続けたいなら"今"に目を向けよう
.NET はOSS、コミュニティベースで開発している、開発に参加することで、エコシステムがより盛り上がる
Life runs on Code
It's agrate time to be .NET Developer
.NET Core 3.0 + Windows 10 で WPF 開発
Kazuki Ota (@okazuki)
資料
今日のゴール
WPF
- Windows Presentation Foudation
- 3.0から登場
- イマイチ流行った印象がない
- WinFormsが強い
- Visual StudioがWPFで作られている
- XAMLベース
- 見た目を柔軟にいじれる
.NETの今後 WPF的には
- .NET Frameworkで今後考えられること
- 対応しないライブラリの登場
- C#の最新言語仕様に対応しきれない
.NET Coreへいくメリット
- ランタイム込みでデプロイにも対応(バージョン問題を解決できる)
- シングルバイナリ(EXE)での提供
.NET Coreへいくデメリット
- サポートライフサイクルが短い
- Windows組み込みではないので、ランタイムの更新は考えないと行けない セキュリティアップデートなど
.NET Frameworkから.NET Coreへ移行
移行ドキュメントを読め
.NET Frameworkからの移行時の苦しみ
互換性があるかわからない
→ .NET Portability Apanalyzerがあるよ! Visual Studioの拡張機能突破してもPlatformNotSupportedException
→ Microsoft.DotNet.Analyzers.Compatibilityがあるよ! 現状プレリリース版。 NuGetはプレビュー版を選択できるようにする- Blend SDK(Behavior)がディスコン
→ Microsoft.Xaml.Behavios.Wpfを使おう
Windows 10対応
サポートされているWindows 10 API
MSIX
Visual Sutdioにパッケージ化する機能がある Windowsアプリケーションパッケージプロジェクト
更新
- 次回起動時にチェックして、次々回時に更新するのがデフォルトの設定
- 更新しないと起動しないようにも設定できる
XMAL Islands
https://docs.microsoft.com/ja-jp/windows/apps/desktop/modernize/xaml-islands
参考
Inside FastEnum
Takaaki Suzuki (@xin9le)
資料
高速化
今日からできる!簡単.NET高速化 Tips https://www.slideshare.net/xin9le/dotnetperformancetips-170268354
CEDEC 2018 最速のC#の書き方 - C#大統一理論へ向けて性能的課題を払拭する https://www.slideshare.net/neuecc/cedec-2018-c-c
速いものを使う
- NET Core
- ASP.NET Core
Enum is too late
FastEnum の方が20万倍〜30万倍速い
Static Type Caching
- 静的コンスタラクタ 一度だけ動くことが保証されるので、排他不要
Unsafe.As
同じメモリ領域を別の型で参照することができる Cのポインターのキャストみたいだな。
感想
性能改善はナノ秒のオーダーなのか。恐れ入りました。
いつか言ってみたいセリフ。
「会社ではなく世界に貢献しているです。」
「早すぎて測定できない」
C# 8.0 非同期ストリーム
Nobuyuki Iwanaga (@ufcpp)
資料
- C# 8.0 非同期ストリーム
非同期ストリーム
C# 8.0 再帰パターン、switch式などプレビューから安定してる機能
https://www.slideshare.net/ufcpp/c-80-preview-in-visual-studio-2019-160C# 8.0 null許容参照型
https://www.slideshare.net/ufcpp/c-80-null
C# 8.0の残りの大物が非同期ストリーム。それを今日説明する。
「複数のデータ」という点が非同期メソッドから非同期ストリームへの変更点
- awaitとyieldの混在:複数のデータを非同期に返す
- await foreach:複数のデータを非同期に受け取る
非同期ストリームの例 gRPC
gRPCのサンプルのリポジトリ https://github.com/ufcpp/UfcppSample/tree/master/Demo/2019/NetCoreGrpc>
proto定義 Microsoft独自なことをしておらず、普通のProtocol Buffers
C# 8.0の言語構文・ライブラリ的な説明
- 非同期メソッドの拡張
- awaitとyieldの混在
- async修飾子を付ける
- 戻り値はIAsyncEnumerable
型
- 非同期foreach
- await foreach (var x in asyncStream)
- IAsyncEnumerable
(と同じ名前のメソッドを持つ型)を受け付ける
- (おまけで)非同期using
- await using (var x = asyncResource)
- IAsyncDisposable (と同じ名前のメソッドを持つ型)を受け付ける
要求されるフレームワーク
- .NET Standard2.1/.NET 3.0では標準提供 最近のMSの方針としては基本的に古いバージョンへのバックポートはしない。 非同期ストリームだけは例外。下位バージョンにもNuGetパッケージで提供
Task周りの歴史
Taskクラス初期導入から非同期ストリームまでC#がおかれている当時の
背景も踏まえての説明。
Unity Trackの資料
Clean Architecture for Unity
https://www.slideshare.net/monry84/clean-architecture-for-unity
MagicOnion〜C#でゲームサーバを開発しよう〜
https://www.slideshare.net/torisoup/magiconionc
Riderはいいぞ!
https://speakerdeck.com/ryotamurohoshi/riderhaiizo
C#×LLVM=アセンブラ!? 〜詳説・Burstコンパイラー〜
https://learning.unity3d.jp/3973/
講演動画もあり。
他の方の感想・まとめ
登壇者ブログ
.NET Core 3.0 + Windows 10 で WPF 開発 というタイトルで .NET Conf 2019 で登壇してきました
マイクロソフト様で開催された「.NET Conf in Tokyo 2019」でRiderの話をしてきた #dotnetconf
参加者グログ
- 【勉強会レポ】: .NET Conf in Tokyo 2019 (Unity Track)
- .NET Conf in Tokyo 2019
- .NET Conf in Tokyo 2019に行ってきました #dotnetconf #dotnetconfunity
- .NET Conf in Tokyo 2019に行ってきました
- .NET Conf in Tokyo 2019 に参加してきました #dotnetconf
- .NET Conf in Tokyo 2019に参加してきた
Twtiterまとめ
「JJUG ナイトセミナー Java O/Rマッパー特集」のメモ
【東京】JJUG ナイトセミナー 「Java O/Rマッパー特集」 7/26(水)開催 久しぶりの勉強会。久しぶりのOracl。実は会場に参加したのは初めだったJJUG。
メモ書き。
比較
機能 | JPA | MyBatis | Doma | Reladomo |
---|---|---|---|---|
マッピング | テーブル | ResutlSet | ResultSet | テーブル |
SQL | 書かない | 書く | 書く | 書かかない |
(書こうと思えば書ける) | ||||
設定 | アノテーション | XML or | Javaクラス + | xml |
アノテーション or | SQLファイル | |||
DSL |
25分でわかるJPA
資料
ここがスゴイ!
- DB製品に依存しない操作が記述できる
- 1対多のようなリレーションを表現できる
- @OneToOne
- @OneToMany
- @ManyToOne
- @ManyToMany
ここがダメ!
- DB製品には依存しないが、JPAの実装に依存する部分がある
その他
- エンティティの状態遷移が重要
- merge()は、引数自体はMANAGED状態にならないので注意
- フェッチは基本LAZY
- JPAを使っていい条件(AND)
次に
- JPAサンプルコード
- 50分で分かるSpring Data JPA
- はまる!JPA(初学者向けライト版)(@suke_masa)
- はまる!JPA (@makingさん)
- JPAの同時実行制御とロック (@suke_masa)
- @opengl_8080さんのQiita記事一連
- パーフェクトJava EE
MyBatis を利用した Web Application 開発についてのご紹介
資料
ここがスゴイ!
- どんなスキーマでも使える
- 主キーがなくても大丈夫
- MyBatis前提でない既存のDBでも
- サブクエリなどの複雑なクエリも書ける
(クエリが自動生成ではなく自分で書いてるので)発行されるクエリが人間に読みやすい
- O/Rマッパーだとどこでクエリが生成されてるのか、どういうクエリが実行されているのかを意識しながらレビューするのはつらい
- Site Reliability Engineerの人が横断的にクエリをレビューする
- Github Enterpriseで検索、どこで動いてるかをすぐに検索できる
DBのパフォーマンスを最大限活かすSQLを書ける
- 自社サービスなら別DBへの移行なんてめったいにしないから
ここがダメ!
その他
次に
ざっくりわかるDoma
資料
ここがスゴイ!
- コンパイル時にコード検証、コード生成
- 他のJARに依存しない
- ページネーション、悲観排他ロックなどRDBMSの差異を吸収
- Java 8以降に対応
- 日付を扱う場合にLocalDateが扱える
- 2 way SQL
- バインドなどをコメント形式で行うので、SQLファイルの中身をコピペしてクエリ発行できる
- エラーメッセージ、ドキュメントなど日本語で手厚いサポート
ここがダメ!
- SELECTクエリの自動生成ができない
- 親子などの構造を持ったエンティティへのマッピングができない
- エラーメッセージ、ドキュメントなどが現状日本語のみ
その他
- markdownのコメント(???)のところに説明してくれた内容のポイントが書いてある http://backpaper0.github.io/ghosts/doma-zakkuri/slide.md
次に
Reladomo入門
資料
ここがスゴイ!
- OSS化されのたは2016だが、2004からゴールドマン・サックスで開発されてお枯れたフレームワーク
- オブジェクト指向の徹底
- 型安全なクエリー
- XMLからコード、DDLを自動生成
- DBクエリはreladomo、取得後にインメモリー処理でGS Collecitonと使える
- 複数のキャッシュ戦略
- バイテンポラルモデルが簡単に扱える
- 有効時間
- トランザクション時間
ここがダメ!
- 情報が少ない
その他
- 読み方は「リラドモ」
- Relational Domain Object の略
次に
実際になにを使っているか?
JPA > MyBatis > Doma > JDBC直呼び
関連
git logをctrl+cで終了すると、それ以降のコマンドが表示されないの続き
Conemu+Gitのbashでgit logをctrl+cで終了すると、それ以降のコマンドが表示されないの続き。
疑問は残ったまま。
発端
あるある。
— 非実在naka aki (@naka_aki_spl) 2017年2月22日
あれ?minttyでも起きる気がする。
あとlessってそもそもctrl-cで止まるものでしたっけ?30年wくらいqしか使ってなかったや。
そうね、Linuxだとq
で止めてるんだけど、Windowsだと、たまにCtrl+c
に指が動いてしまう。
これ書いていて気づいた。
Git Bash
って、Gitインストール先\bin\bash.exe
じゃなくて、Gitインストール先\git-bash.exe
なのね。
mintty と書いたのは、Git Bash
で、Gitインストール先\bin\bash.exe
のこと。
なので、改めて確認。
git-bash.exeとbash.exeでCtrl+cで止める
スクロール待ちになっている状態のgit log
と普通に起動したless
に対して、
Ctrl+c
で止める。
ターミナル | git log | less |
---|---|---|
git-bash | 終了して、それ以降のコマンドも正常に表示される | 終了しない |
bash | 終了して、それ以降のコマンドは表示されない | 終了しない |
bashだと発生する。conemu関係なかった。
kill -INTで止めるとどうなるか?
スクロール待ちになってる状態のgit log
と、git log
から起動したless
対して
kill -INT
で止める。
ターミナル | git log | less |
---|---|---|
git-bash | 終了して、それ以降のコマンドも正常に表示される | 終了しない |
bash | 終了して、それ以降のコマンドも正常に表示される | 終了しない |
送信するシグナルの確認
git-bash
でもbash
でも、stty -a
の実行結果はintr = ^C;
なので同じはず。
疑問
kill
で指定したプロセスに対してSIGINTだと問題ないということは、
bash
でCtrl+c
でプロセスグループに属する全プロセスに対して送信するとダメのか?
そこに、Git bash
とbash
の違いがあるのか?
分からん。だれか教えて。
Conemu+Gitのbashでgit logをctrl+cで終了すると、それ以降のコマンドが表示されない
現象
ConemuのGit for WindowsのBash上で、git log
を実行しCtrl+c
で終了すると、それ以降の
入力したコマンドが表示されない。
コマンドは実行されて、標準出力、標準エラーは表示される。
Git for WindowsのBashとは、gitインストール先\bin\bash.exe
のこと
再現手順
- ConemuでGit for WindowsのBashを開く。
git log
、git diff
などを実行する。- 2.の出力表示が2ページ以上で、スクロール待ちの状態にする。
Ctrl + c
で2.のコマンドを終了する。- 何らかのコマンドを入力して、Enterで実行する。
発生しない条件
- ConemuとGit for WindowsのBashで、
Ctrl +C
の代わりにq
で終了した場合は、問題は発生しない - ConemuとGit for WindowsのBashで、lessを使用した場合は、そもそも
Ctrl+C
での終了を受け付けない - Git for Windowsに付属するGit Bash(mintty)上では、
git log
、git diff
をCtrl+cで
終了しても問題は発生しない
環境
- OS
Windows 10 バージョン1607(ビルド14393.693) - Git
git version 2.11.1.windows.1 - Conemu
161206 stable - CoemuからGit for WindowsのBashを起動する設定。
-new_console:d:C:\Users\clover -cur_console:C:C:\usr\opt\git\etc\git.ico C:\opt\git\bin\bash.exe --login -i
原因
分からない。
Git bash(mintty)で発生しないということは、Conemuの問題なのか?
実験
復旧方法の実験
コマンド | 結果 |
---|---|
clear | 戻らない |
echo ^[c | 戻らない |
reset | 正常に戻る |
stty sane | 正常に戻る |
復旧方法
Ctrl + c
で終了させてしまい、コマンドが表示でされなくなってしまったら、reset
かstty sane
を
実行して 端末制御をきれいにすると、コマンドが表示されるようになる。
抑止方法
q
で終了させる。
Ctrl + c
の終了で正常に終了させる方法はわからない。
参考
Git for Windows 2.xでプロンプトの設定(PS1)にブランチ名と改行を入れるとsyntax errorになる
Git for Widnows 2系に上げてから、設定(PS1)にブランチ名と改行を入れるとsyntax errorに
なるようになった。
対処方法がわからなかったので、しばらく、改行を外していて放置してた。
現象
bash: command substitution: line 1: syntax error near unexpected token `)' bash: command substitution: line 1: `__git_ps1)'
条件
- Git for Widnows 2.xを使用してる。
- PS1に
__git_ps1
でブランチ名を設定してる。 - PS1に改行(
\n
)を設定している。
例
export PS1='\w$(__git_ps1)\n\$ '
問題にならない条件
Git for Widnows 2.xでも以下の条件ではsyntax errorにならない
- ブランチ名がない場合
export PS1='\w\n\$ '
- 改行の設定がない場合
export PS1='\w$(__git_ps1)\$ '
- ブランチ名がない場合
Git for Widnows 1.xを使っている場合はsyntax errorにならない
- Linuxで、Gitを使ってる場合はsyntax errorにならない
環境
以下の環境だとsyntax errorになる。
調査
LinuxではGit 1.x、2.xでも発生しないから、Git for Widnowsの問題だろう。
WindowsだとGit 1.xでは問題なかった。
2.xになってから、なにか変更があったっぽい。
ぐぐったら事例は出てきた。
PS1 bash command substitution not working on windows 10
'\n$'
を$'\n$ '
にすればいいみたい。
なんで?
Cygwinの事例なら、原因が書いてあった。
Cygwin のプロンプトに Git のブランチを表示する(シンタックスエラーが発生した場合の対策あり)
構文解析でエラー
Cygwin 環境では $PS1 のコマンド置換でシンタックスエラーが出ることがあります。
-bash: command substitution: line 1: syntax error near unexpected token `)'
-bash: command substitution: line 1: `__git_ps1)'
これは改行コード CR を無視する Cygwin 独自のシェルオプション igncr による影響の
ようです。igncr が設定されている場合,$PS1 内で $( ) 形式のコマンド置換の後に
\n が続くと構文解析に失敗してしまいます。バッククォートによる旧式のコマンド置換
ではこの現象は発生しません。
CRが悪さしてるのか。
igncrの設定がGit for Widnows 2.xから変わった?
確認してみる。
Git for Windows 1.9.4の環境
$ git --version git version 1.9.4.msysgit.1
$ bash --version GNU bash, version 3.1.0(1)-release (i686-pc-msys) Copyright (C) 2005 Free Software Foundation, Inc.
$ set -o allexport off braceexpand on emacs on errexit off errtrace off functrace off hashall on histexpand on history on ignoreeof off interactive-comments on keyword off monitor on noclobber off noexec off noglob off nolog off notify off nounset off onecmd off physical off pipefail off posix off privileged off verbose off vi off xtrace off
igncrの項目は無い。無いけど有効になっているのか?
Git for Windows 2.11.1
$ set -o |grep igncr igncr off
offだな。
2.xでなにが変更になったかは、確認できず。。。
対処
対処は、Cygwin のプロンプトに Git のブランチを表示する(シンタックスエラーが発生した場合の対策あり)に載っているもののうちの以下の2つ。
バッククォート形式にする
export PS1='\w`__git_ps1`\n\$ '
改行を$'\n'にする
export PS1='\w$(__git_ps1)'$'\n$ '
後者を選択。
$'\n'ってなに?
BASHより
$'string' の形式を持つ単語は特殊な扱いを受けます。 この単語は string に展開され、
それから ANSI C 標準で仕様が決められている、 バックスラッシュでエスケープされている
文字に置き換えられます。 バックスラッシュエスケープシーケンスは、 (もし存在すれば)
以下のようにデコードされます:(省略)
- \n
改行
vagrant のプロビジョニングでgit cloneがSSHの認証エラーになる
やりたいこと
初回のvagrant up、vagrant up --provision、vagrant provisionでの
プロビジョニングでgithubやbitbucketからクローンしたい。
が、エラーになってしまう。
vagrant sshでログインしてからのgit cloneは成功する。
provisionでやろうとするとエラーになる。
なんかWindows版のバグ踏んでるんだろうか。。。
ホストがWindowsでうまくいってる方がいたら教えて下さい。
エラー
==> default: Cloning into '/path/to/repository'... ==> default: Error reading response length from authentication socket. ==> default: Permission denied (publickey). ==> default: f ==> default: atal: ==> default: C ==> default: ould not read from remote repository. ==> default: ==> default: Please make sure you have the correct access rights ==> default: and the repository exists. The SSH command responded with a non-zero exit status. Vagrant assumes that this means the command failed. The output for this command should be in the log above. Please read the output to determine what went wrong.
vagrantfile
Vagrant provision でも SSH Agent Forwarding するを参考に、 forward_agent、privileged、StrictHostKeyCheckingの設定をしている。
config.ssh.forward_agent = true config.vm.provision "shell",privileged: false, inline: <<-SHELL sudo apt-get install -y git-core echo -e "Host bitbucket.org" > ~vagrant/.ssh/config echo -e " StrictHostKeyChecking no" >> ~vagrant/.ssh/config git clone git@bitbucket.org:path/to/private/repository /path/to/repository SHELL
手順
$ eval `ssh-agent` $ ssh-add ~/.ssh/id_rsa.bitbucket.org $ vagrant up --provision
確認したこと
privileged
provisionでidコマンドを実行すると以下になっているので、privilegedの設定は有効になっていて vagrantユーザーで動作してる。
==> default: uid=1001(vagrant) gid=1001(vagrant) groups=1001(vagrant)
SSH Agent Fowrdingの設定
vagrant sshでログインしてからgit cloneするとパスワード入力せずに認証できるから、設定は問題ない。
remote: Counting objects: 17370, done. remote: Compressing objects: 100% (11174/11174), done.
provisionでssh-add -lを実行するとエラーになってる
Error reading response length from authentication socket.
環境
- ホストOS:Windows 8.1
- ゲストOS:ubunts 12.04
- Vagrant:1.7.4
- Oracle VirtualBox:5.0.6
- Git:1.8.5.2.msysgit.0 gitが古いな。。。
Windows + VirtualBox 5.0 + Vagrant 1.7.3 でエラー(chown: changing ownership of `/vagrant': Not a directory)になる
Oracle VM VirtualBox 5.0 + Vagrant 1.7.3 でchown: changing ownership of `/vagrant': Not a directory のエラーになるんだけど、対処方法がわからない。 教えてください。
現象
Vagrant assumes that this means the command failed! chown `id -u vagrant`:`id -g vagrant` /vagrant Stdout from the command: Stderr from the command: stdin: is not a tty chown: changing ownership of `/vagrant': Not a directory
環境
- Oracle VM VirtualBox 5.0
- Vagrant 1.7.3
- box
- Official Ubuntu 12.04 daily Cloud Image amd64 (VirtualBox 4.1.12)
- https://cloud-images.ubuntu.com/vagrant/precise/current/precise-server-cloudimg-amd64-vagrant-disk1.box
- Guest Additionsが有効になっている
vagrant-vbguest を入れてみたけどダメだった。
http://kashewnuts.bitbucket.org/2013/08/25/vagrantvbguest.html
Guest Additions の Version が古いのが原因らしい。 なので、自動的にGuest Additionsを更新してくれるプラグインを導入。
とあるので、これを試してみた。 vagrant plugin install vagrant-vbguest の後、vagrant upしてみたが、 エラーは変わらず。
clover@NARANJA ~ $ vagrant plugin install vagrant-vbguest Installing the 'vagrant-vbguest' plugin. This can take a few minutes... Installed the plugin 'vagrant-vbguest (0.10.0)'! clover@NARANJA /c/MyVM/ubuntu1204 $ vagrant up Bringing machine 'default' up with 'virtualbox' provider... ==> default: Clearing any previously set forwarded ports... ==> default: Clearing any previously set network interfaces... ==> default: Preparing network interfaces based on configuration... default: Adapter 1: nat ==> default: Forwarding ports... default: 22 => 2222 (adapter 1) ==> default: Booting VM... ==> default: Waiting for machine to boot. This may take a few minutes... default: SSH address: 127.0.0.1:2222 default: SSH username: vagrant default: SSH auth method: private key ==> default: Machine booted and ready! GuestAdditions versions on your host (5.0.0) and guest (4.2.0) do not match. stdin: is not a tty Reading package lists... Building dependency tree... Reading state information... The following extra packages will be installed: fakeroot linux-headers-3.2.0-23 patch Suggested packages: diffutils-doc The following NEW packages will be installed: dkms fakeroot linux-headers-3.2.0-23 linux-headers-3.2.0-23-generic patch 0 upgraded, 5 newly installed, 0 to remove and 66 not upgraded. Need to get 12.6 MB of archives. After this operation, 68.2 MB of additional disk space will be used. Get:1 http://us.archive.ubuntu.com/ubuntu/ precise/main patch amd64 2.6.1-3 [80.2 kB] Get:2 http://us.archive.ubuntu.com/ubuntu/ precise/main dkms all 2.2.0.3-1ubuntu3 [73.1 kB] Get:3 http://us.archive.ubuntu.com/ubuntu/ precise/main fakeroot amd64 1.18.2-1 [87.2 kB] Get:4 http://us.archive.ubuntu.com/ubuntu/ precise/main linux-headers-3.2.0-23 all 3.2.0-23.36 [11.4 MB] Get:5 http://us.archive.ubuntu.com/ubuntu/ precise/main linux-headers-3.2.0-23-generic amd64 3.2.0-23.36 [947 kB] dpkg-preconfigure: unable to re-open stdin: No such file or directory Fetched 12.6 MB in 38s (330 kB/s) Selecting previously unselected package patch. (Reading database ... 51105 files and directories currently installed.) Unpacking patch (from .../patch_2.6.1-3_amd64.deb) ... Selecting previously unselected package dkms. Unpacking dkms (from .../dkms_2.2.0.3-1ubuntu3_all.deb) ... Selecting previously unselected package fakeroot. Unpacking fakeroot (from .../fakeroot_1.18.2-1_amd64.deb) ... Selecting previously unselected package linux-headers-3.2.0-23. Unpacking linux-headers-3.2.0-23 (from .../linux-headers-3.2.0-23_3.2.0-23.36_all.deb) ... Selecting previously unselected package linux-headers-3.2.0-23-generic. Unpacking linux-headers-3.2.0-23-generic (from .../linux-headers-3.2.0-23-generic_3.2.0-23.36_amd64.deb) ... Processing triggers for man-db ... Setting up patch (2.6.1-3) ... Setting up dkms (2.2.0.3-1ubuntu3) ... Setting up fakeroot (1.18.2-1) ... update-alternatives: using /usr/bin/fakeroot-sysv to provide /usr/bin/fakeroot (fakeroot) in auto mode. Setting up linux-headers-3.2.0-23 (3.2.0-23.36) ... Setting up linux-headers-3.2.0-23-generic (3.2.0-23.36) ... Examining /etc/kernel/header_postinst.d. run-parts: executing /etc/kernel/header_postinst.d/dkms 3.2.0-23-generic /boot/vmlinuz-3.2.0-23-generic Downloading VirtualBox Guest Additions ISO from http://download.virtualbox.org/virtualbox/5.0.0/VBoxGuestAdditions_5.0.0.iso Progress: 100% (Rate: 11.2M/s, Estimated time remaining: --:--:--) Copy iso file D:/vagrant.d/tmp/VBoxGuestAdditions_5.0.0.iso into the box /tmp/VBoxGuestAdditions.iso stdin: is not a tty mount: warning: /mnt seems to be mounted read-only. Installing Virtualbox Guest Additions 5.0.0 - guest version is 4.2.0 stdin: is not a tty Verifying archive integrity... All good. Uncompressing VirtualBox 5.0.0 Guest Additions for Linux............ VirtualBox Guest Additions installer Removing installed version 4.2.0 of VirtualBox Guest Additions... Copying additional installer modules ... Installing additional modules ... Removing existing VirtualBox DKMS kernel modules ...done. Removing existing VirtualBox non-DKMS kernel modules ...done. Building the VirtualBox Guest Additions kernel modules ...done. Doing non-kernel setup of the Guest Additions ...done. Starting the VirtualBox Guest Additions ...done. Installing the Window System drivers Could not find the X.Org or XFree86 Window System, skipping. An error occurred during installation of VirtualBox Guest Additions 5.0.0. Some functionality may not work as intended. In most cases it is OK that the "Window System drivers" installation failed. stdin: is not a tty Cleaning up downloaded VirtualBox Guest Additions ISO... ==> default: Checking for guest additions in VM... ==> default: Mounting shared folders... default: /vagrant => C:/MyVM/ubuntu1204 The following SSH command responded with a non-zero exit status. Vagrant assumes that this means the command failed! chown `id -u vagrant`:`id -g vagrant` /vagrant Stdout from the command: Stderr from the command: stdin: is not a tty chown: changing ownership of `/vagrant': Not a directory
Guest Additionsが入っていないのは、起動時にエラーはでない。
vagrant sshでログインはできる。
原因
Windows版Vagrantのバグ
- Windows + VirtualBox + Vagrant 1.7.3は正常に動作しません
- Unable to mount /vagrant folder in 1.7.3 #5933
Windowsだけか・・・
対処
- Vargrant 1.7.4が出るまで待つ
- VitatualBox 4.3.30 + Vargrant 1.7.2にダウングレードする
- Guest Additionsが入っていないBoxを使う