銀の光と碧い空

クラウドなインフラとC#なアプリ開発の狭間にいるエンジニアの日々

.NET Core

OpenTelemetry .NETを理解する (5) HttpClientによる外部通信処理を計測する

前回はスパンに情報を追加しました。 tech.tanaka733.net 次にトレースをさらにスパンで区切ってどの処理に時間がかかっているか計測することにします。スパンは作業の単位で区切ります。原理的には1メソッド1スパンで記録することもできますが、計測のオー…

OpenTelemetry .NETを理解する (4) Spanに情報を追加する

今回は、第2回目で計装したコードを基に、計測したSpanに情報を追加してみます。 tech.tanaka733.net 以下のコードを出発点にします。 app.MapGet("/weatherforecast", (ILogger<Program> logger, HttpContext context) => { var forecast = Enumerable.Range(1, 5).S</program>…

OpenTelemetry .NET ハンズオンを行いました

C# Tokyoでの企画でOpenTelemetryの初心者向けハンズオンを行いました。 csharp-tokyo.connpass.com OpenTelemetry .NETについての発表資料はこちらです。 202202 open telemetry .net handson from Takayoshi Tanaka www.slideshare.net ハンズオン課題はこ…

OpenTelemetry .NETを理解する (2) ASP.NET CoreにOpenTelemetryをまずいれてみる

今回からは実際にOpenTelemetry .NETを使って計測してみることにします。まずは、ASP.NET Core (.NET 6)を題材にします。 OpenTelemetryのドキュメントと重なる部分も多いのであわせて参照してみてください。 opentelemetry.io 最初の計装 まずは、計測対象…

.NET 5 関連の新機能をまとめてみた

11月の.NET Confでリリースが予定されているされた .NET 5 関連の新機能をできるだけまとめてみました。ASP.NET CoreとEF Coreは除いています。 リリースにあわせていくつか更新しています。 そしてそんな .NET 5に興味のある方はぜひこちらのイベントにご参…

System.Text.JsonやJson.NET で一部だけキーが可変なJSONを処理する

とあるREST APIのエンドポイントが /values/xxx みたいなエンドポイントに対して次のような形式のJSONを返します(実際にはこの3倍くらい属性があり、listの中の配列も多数あります)。XXXで指定した名前の値のリストを取得するというイメージで、この名前のパ…

ISUCON9の参考実装をC# (ASP.NET Core 3.1)に書き換えてみた

ISUCONは説明不要の一大イベントだと思います。簡単にいうと、お題に従いより高速なWebアプリケーションを構築するコンテストです。昨年行われたISUCON9の本戦問題についてはこちらに記事があります。 isucon.net さて、このISUCON9、参加者は予め用意されて…

.NET Standard の HttpClientで送信時のBodyをgzip圧縮したい

HttpClientでPOSTやPUTのような送信を行う場合に、Bodyで送信するコンテンツをGZip圧縮したいと思ったのですが、意外とすぐに使えるサンプルコードが見当たりませんでした。 docs.microsoft.com とりあえず動くコードは書けたので、メモしておきたいと思いま…

NupkgファイルをGiHub PackageにPublishするGitHub Actionを作りました

github.com というGitHub Actionを公開しました。 作った背景ですが、まずGitHub Actionsの中でGitHub PackageにNuGetパッケージを公開する手順は、Windows限定で昨日の記事に書きました。 tech.tanaka733.net 公開リポジトリならWindowsでも無料なので気に…

NupkgファイルをGiHub PackageにPublishするGitHub Actionを作りました

github.com というGitHub Actionを公開しました。 作った背景ですが、まずGitHub Actionsの中でGitHub PackageにNuGetパッケージを公開する手順は、Windows限定で昨日の記事に書きました。 tech.tanaka733.net 公開リポジトリならWindowsでも無料なので気に…

NupkgファイルをGiHub PackageにPublishするGitHub Actionを作りました

github.com というGitHub Actionを公開しました。 作った背景ですが、まずGitHub Actionsの中でGitHub PackageにNuGetパッケージを公開する手順は、Windows限定で昨日の記事に書きました。 tech.tanaka733.net 公開リポジトリならWindowsでも無料なので気に…

GitHub Actionsで作成したNuGetパッケージをGitHub Packagesに公開する

久しぶりにNuGetパッケージを公開したくなったのですが、最近だとGitHubで公開しているのならGitHub Actionsでビルドするのが簡単なようです。 tech.guitarrapc.com 最終的には作成したパッケージは nuget.org に公開するのですが、いったんprivateなNuGetリ…

ASP.NET Core 3 Web APIで例外をスローして、指定したステータスのレスポンスを返す

ASP.NET Core Web APIでアプリケーションロジック内では例外を投げておいて、共通処理として例外をキャッチして例外に応じたステータスコードとメッセージのレスポンスを返したい場合があるかと思います。ASP.NET Framework やCore 2.2まであったHttpRespons…

DateTimeとTimeSpanの書式文字列が違うという話

知ってればそれだけなのですが、System.DateTimeとSystem.TimeSpanでは指定できる書式文字列が異なります。知らずによくわからないエラーを出して一瞬困りました。 たとえば、DateTimeオブジェクトで時間のところで HH:mm:ss という形式で出力したい場合は次…

.NET Core で暗号論的疑似乱数生成器を使ってソルトを作成し、PBKDF2でパスワードのハッシュ化を試みる

この時代、自前でパスワードの管理などしたくはないのですが、しないといけないケースもあるでしょう。最低限やらないといけないこととしては、ソルト生成した上でハッシュ化したパスワードを保存することではないでしょうか。.NET Coreでこれらの処理を行う…

.NET CoreでUTCのISO8601形式の時刻文字列から指定のタイムゾーンに変換する

例えば 2020-03-23T12:00:00.000Z というUTCでのISO8601形式の文字列をパースしたうえで、指定したタイムゾーンでの時間に変換したいとします。2020-03-23T12:00:00.000Zであれば、日本標準時(UTC+9)で2020年3月23日21時です。これは次のようなコードで処理…

.NET CoreでWindowsとLinuxでタイムゾーンを識別するID表記が異なるという話

最近、ASP.NET CoreでTimeZoneまわりのコード書いてて遭遇しました。以前このブログ読んだ記憶はあるのですが、すっかり忘れていました。そして、.NET Core 3でもそのままなんだなというのがわかりました。 devblogs.microsoft.com .NET Coreで特定のTimeZon…

Visual Studio 2019 Launch Event in Tokyoで.NET Core向けコンテナおよびデバッグ関連のVisual Studio 2019の機能について話しました

Visual Studio 2019 Launch Event in Tokyoを開催しまして、登壇もしました。 connpass.com 発表資料はこちらです。 .NET Core向けコンテナおよびデバッグ関連のVisual Studio 2019の機能 from Takayoshi Tanaka www.slideshare.net 今回、手持ちのノートPC…

.NET Core on OpenShift でのHTTPSサポートの紹介

ひとりAdvent Calendar 14日目です。 adventar.org ASP.NET Core 2.1からHTTPS対応の改善が入っています。 blogs.msdn.microsoft.com OpenShift上の.NET Coreでもこれをサポートするサンプルが提供されていて以下のブログで解説されています。それを紹介して…

.NET Core コンソールアプリをOpenShiftのcronjobとして動かす

ひとりAdent Calendar13日目です。 adventar.org 昨日紹介したbinary artifactsのビルドを使って、.NET Core コンソールアプリをcronjobとして動かしてみます。

OpenShift で ASP.NET CoreアプリをBinary Artifactsとしてデプロイしてみる

ひとりAdvent Calendar 12日目です。 adventar.org 今日は手元でビルトした.NET CoreアプリのバイナリをアップロードしてOpenShiftにデプロイできるBinary Artifactsデプロイを試してみます。

.NET Coreでダンプファイルを解析できる ClrMD を試してみた

ひとりAdvent Calendar 11日目です。 adventar.org ClrMDと呼ばれているMicrosoft.Diagnostics.Runtime.dllが.NET Coreに対応したと聞いて試してみました。プロセスへのアタッチやダンプファイルの解析で、SOS and PSSCORといったツールを使ってやっているこ…

.NET Coreにおける新元号対応について

MVPグローバルサミットに参加している最中に新元号対応が気になったのでマイクロソフトのエンジニアに聞いてみたら、publicなissueで議論しようということだったので立ててみました。するとあっという間に回答が来たので、日本語で簡単にまとめてみようと思…

FedoraやRHELの.NET CoreでVisual Studio CodeでのC# コード編集支援機能が使えない場合の対処法

.NET Core 2.0でRHELもcsproj形式をサポートしたり、Fedoraもサポートされるようになったのですが、Red HatやFedoraコミュニティから提供されている.NET Core SDKを入れた状態でVisual Studio CodeでC#プロジェクトを開いてもプロジェクトをロードできないと…

ふくてん Fukuoka .NET Conf で ASP .NET Coreのセッションをしました

国内では初めて東京近郊以外の地域*1でセッションしました。資料はこちらです。 ASP.NET Core のお気に入りの機能たち (docker向け) from Takayoshi Tanaka www.slideshare.net セッションで紹介した(しようとした)サンプルコードのGitHubリンクはこちらで…

Red Hat Container Development Kit を使って、.NET Core on Linux containerを無料で体験する

先日の記事に続いて、Red Hat Developer Programを利用しての無料体験の宣伝です。 developers.redhat.com .NET Core on RHEL (Red Hat Enterprise Linux Server)はRHELサーバー上でも動くのですが、Container Platform製品であるOpenShift上での利用もおす…

OpenShift で .NET Core 2.0を使いはじめる

先日、Red Hat版*1の.NET Core 2.0がリリースされました。 tech.tanaka733.net Getting Started Guide - Red Hat Customer Portal 続いてOpenShiftでも利用可能なコンテナやテンプレートも提供されました。OpenShift本体のアップデートとは別ものとして、イ…

Red Hat版 .NET Core 2.0 のリリースや、OpenShiftのWindows Server Containerサポートなどが発表されました

Red HatとMicrosoftが協力している技術分野に関して立て続けにプレスリリースが発表されています。いくつかの内容についてはすでに発表済みですが、再度まとめての記事になっているようです。 www.redhat.com www.redhat.com news.microsoft.com 技術的な詳…

ASP.NET Core 2.0 preview 2 では C# 7.1 の構文がRazor Viewの中で使えなかった話

このissueのやり取りがすべてなんですが、備忘録として残しておきます。 github.com

2017年 .NET Core 1.x (Visual Studio 2017) プロジェクト向け AppVeyor での自動ビルドの設定

ChatWork 向けのC# クライアントを開発していて、ここ1~2年は更新していなかったものの、最近.NET Core対応させたり、API endpoint v2に対応したりしてまた更新するようになりました。 github.com 2年前にAppVeyorで自動ビルド環境を作っていましたが、当時…