production.log

株式会社リブセンスでエンジニアをやっている星直史のブログです。

技術

InstagramグラフAPIのプラットフォーム利用規約違反対応をしました

SnapmartアプリではInstagramグラフAPIを使用しているのですが、8月下旬にMeta社より「プラットフォーム違反しているからAPI利用停止するね」とお達しがありました。この記事では、InstagramグラフAPIのプラットフォーム利用規約違反対応内容を紹介していき…

AWS EC2 Ubuntu 14.0.4インスタンスをT2からNitro世代(T3)に移行で「FATAL: Could not load /lib/modules」または「BusyBox」 (カーネルモジュールの欠如)によりステータスチェックが1/2になってしまった時の対応方法

年に一度RI購入のためサーバーの棚卸しをするのですが、その時にT2インスタンスがちらほら...。AWSも最新のファミリータイプを使用することを推奨しているので、ここいらでT3にするぞと対応したらドハマりしました。今回はAWS EC2 Ubuntu 14.0.4インスタンス…

Novathのモニターになり、数学を学ぶ楽しさとAI(機械学習)を扱えるようになりました。

Novathのサービスページにある受講後の到達地点は以下の通りです。「AI(機械学習)の数学的な本質(ロジック)を理解し、人に説明できる」「ビジネスの現場で役に立つ統計手法(重回帰分析、ロジスティック回帰分析、クラスタリング等)をExcelで使いこなせ…

Railsのエラー通知をアプリケーションコードを変更せずに検知と通知をする方法

サービスを運用していると、エラーを検知/通知する仕組みがほしくなります。 少し調べてみると、RailsでエラーをSlackに通知したいのであれば、exception_notificationとslack-notifierの2つのgemを入れるのが多い印象を受けました。一見良さげに見えたので…

AWS Elasticsearch Service(AES)のシャードの未割り当て(UNASSIGNED)が原因でクラスター状態が黄色になってしまった場合の対応方法

タイトルの通り、ある日突然Amazon Elasticsearch Service(以下AES)のクラスター状態が黄色になってしまいました。 今回はクラスター状態が黄色になった場合の対処方法について、紹介します。原因は、シャードのいくつかが、ノードに割当されなくなってしま…

AWS Elasticsearch Service(AES)のデータノードが消失しStatusがRedになった場合の対応方法

私が運用しているサービスの一つであるSnapmartで障害が発生しました。 原因はAmazon Elasticsearch Service(以下AES)のデータノードが消失しStatusがRedになったためです。 Elasticsearchのデータノードが消失しているので、検索周りで多大な影響が出てしま…

.bundle/configの内容を公開

.bundle/configの内容を公開

VPCにあるAWS Elasticsearch ServiceのPrivate IPをALBに追加するシェルスクリプト

Snapmartの検索サーバーはAmazon Elasticsearch Service(以下ESS)で運用しているのですが、Kibanaを使ってデータ分析をしたくなりました。ESSはVPC内にあるため、アプリケーションサーバーからElasticsearch APIで検索実行は問題なく行えますが、管理者PCか…

Managed workflowのExpoアプリに導入するE2Eテストフレームワークの比較と導入

運用しているアプリの規模が大きくなってくると、ちょっとした修正が思わぬところに影響してしまったり、ツールのバージョンアップをする際に組織全体を巻き込んだ大規模な手動テストを行わなければならないことがしばしばあります。 自分が運用しているSnap…

ExpoのMediaLibraryからiOSのHEICファイルをアップロードした場合にリサイズできない問題の解決方法

会社で作っているSnapmartアプリは写真のアップロードがメインのアプリです。 Snapmartにおける写真アップロード処理は、ざっくり以下の手順で処理されます。 1. スマホからS3にアップロード 2. S3にアップロードされた画像ベースにLambdaでサムネイル作成 …

SnapmartアプリにFirebaseAnalyticsを導入しました

SnapmartアプリはReact Native + Expoで動いています。 2019年5月にAndroid版をリリースし、2019年12月にiOS版をリリースしました。 リリース当初は不具合や非機能要件を満たせないことが多かったため、その対応に追われることが多かったのは記憶に新しいで…

Expo SDK v36.0.0で追加されたMediaLibraryのお気に入り写真の読み込みが遅い問題と回避策

React Native 0.61からCameraRollが削除されました。 そのため、Expo SDK v36.0.0以降でExpoマネージドアプリを作成している場合は、MediaLibraryを使用して写真を読み込まなければならなくなりました。 CameraRolleでは、「お気に入り」がアルバムの一つと…

Snapmartアプリで使用しているReact Navigationをv4からv5にアップグレードした際の対応

2020年2月にReact Navigationのv5がリリースされました。Snapmartアプリでは、React Navigation v4を使用しています。 React Navigation v4では、Stack NavigatorにJavaScriptを使用していましたが、ネイティブのような感覚とパフォーマンスが低下する場合が…

SnapmartアプリのExpo SDKのバージョンをv35.0.0からv37.0.0にアップグレードで対応したこと

4月1日にExpo SDK v37.0.0がリリースされました。自分が開発に携わっているSnapmartアプリではExpo SDK v35.0.0を使用していました。 Expo SDK v36.0.0がリリースされた際は、Snapmartアプリにとって、アップグレードを行う強いモチベーションがなかったので…

React Nativeにおいて、WebViewでhtml内のリンクをブラウザアプリで処理をする方法

先日、Expoアプリで使うWebViewはreact-native-communityを使わなければ表示させることができないという記事を書きました、今回もWebViewネタ。 WebViewを使用するときは、大きく2つに分かれます。 1. URLを指定する場合2. HTMLを記述する場合 WebViewはWebV…

Expoアプリで使うWebViewはreact-native-communityを使わなければ表示させることができない

ExpoアプリでWebViewを使用する際、以下のソースコードでは、画面に文字列を出力することができません。今回はExpoアプリで使うWebViewはreact-native-communityを使わなければ表示させることができない問題の解決方法を書きます。

RailsでCSVを生成し、Excelで開く時にハマったこと

管理画面的なシステムで、RailsからCSVを出力し、それをエンドユーザーがExcelで開くようなシュチュエーションで困ったことがありました。 * セル内の日本語が文字化けしてしまう * 0埋め文字を生成しても、Excelで先頭の0が除かれてしまう それぞれ5分ほど…

React Native Debuggerの長時間使用時のメモリリークを防ぐ方法

React Nativeを使用したアプリの開発時に必要になるものはデバッガーです。デバッガーにはいくつか種類があります。 * Chrome * VSCode * Reactotron * React Native Debugger * console.log((流石にこれだけだとキツいですが)) これらの中で、私はReact Nat…

AWS EC2上でReact Native + Expo アプリを動かし、手元のスマホに配信する方法

React Native + Expoを使用すると、エミュレータだけではなく、実機でも手軽にアプリの動作を確認することができます。 ただし、制約もあります。 * 実機への配信は、同一のネットワークからでなければ配信することができない * 配信元はローカルのPCとなる…

Re:スムーズに技術書を入稿するためのチェックポイントと値付けについて

技術書典8は新型コロナウィルスにより中止になりましたが、印刷所への入稿が割引率が最も高い早割で申し込むことはできました。 技術書典の参加は今回で2回目でしたが、1回目で覚えた内容をほぼ忘れていたため、 前回メモ書き程度に残した自分のブログを頼り…

ReactNativeでカメラロールから写真を複数枚選択する処理の実装

自分が作っているプロダクトであるSnapmartは、スマホのアプリから誰でも手軽に写真を売り買いできるサービスです。 スマホアプリでは、カメラロールの中から写真をアップロードをする機能があります。 この写真をアップロードする機能ですが、カメラロール…

rake db:migrateでIndex column size too large.と言われてしまった場合の対応

development環境にMySQLを構築して一からmigrationを実行しようとした時に、Index column size too large.と言われてしまいました。 この記事ではrake db:migrationでIndex column size too large.と言われてしまった場合の対応についてメモ程度にまとめます…

ReactNative製AndroidアプリからさらにiOSアプリ実装が終わったのでKPTを行う

SnapmartのAndroidアプリはReact Nativeで実装されています。iOSアプリはSwiftで実装されているのですが、この度、React Nativeで置き換えることにしました。手順は、まずAndroidアプリを作り、それからiOSアプリを置き換えることにしました。((当初そもそも…

AWS S3で特定のバケット内のオブジェクトをワイルドカードを使用して削除するコマンド

AWS S3を利用していると、ある特定のバケット内のオブジェクトをワイルドカードを使って削除したい場面があると思います。 シェルスクリプトのrmコマンドと同じノリでいけるかと思いきや、オプションを指定しなければならなかったので、そのメモを残します。

React Native + ExpoによるiOSアプリ審査申請時の広告ID(IDFA)設定

iOSアプリの審査申請時、広告ID(IDFA)を選択するように言われます。間違った選択をすると審査で落とされてしまうのですが、毎度毎度「どの設定したらいいんだっけ?」と悩まされます。今回は自分用にReact Native + ExpoによるiOSアプリ審査申請時の広告ID(I…

Apache Bench(abコマンド)をmacOSで実行した場合に出るエラー「socket: Too many open files (24)」の回避方法

AWS ELBの暖気申請(Pre-Warming)をしたかったのですが、サポートのプランがBusiness以上でなければ申請できないため、自前でPre-Warmingをする必要がありました。 AWS ELBは負荷が上がった場合に、AutoScaleするLBです。 通常、事前に大量のトラフィックが予…

AWS障害が発生した場合に確認するページやサイトまとめ

2019年8月23日 13時頃からAWS EC2の接続ができなくなる障害が発生しました。 このような大規模障害は滅多にないので、障害の情報収拾する際に「どこみりゃいいんだ?」となるので、この機会にまとめることにしました。この記事ではAWSで障害が発生した場合に…

SnapmartのブログサーバーのSSL証明書をLet's EncryptからAWS Certificate Manager (ACM)に移管しました

先日、SnapmartのブログサーバーのSSL証明書が有効期限切れになってしまい、アクセスすることができなくなってしまいました。これまでSnapmartのブログサーバーではLet's Encrypt という証明書を無料で発行しているサービスを使っていました。しかし、このLe…

【React Native】Expo SDK v33.0.0 へのアップグレード手順

今年の1月にGoogleが「今後Androidアプリは64bit対応してないとダメだよ!8月1日以降32bitのアプリはリリースできないからね!」というアナウンスをしました。SnapmartアプリはReactNativeで実装しており、開発ツールとしてExpoを使っています。ExpoはSDKの…

ReactNative 0.59.8のCameraRoll.getPhotosでInvalid filter option: '(null)'. Expected one of 'photos','videos' or 'all'.が発生した場合の回避方法

タイトルの通り、ReactNative 0.59.8において、`CameraRoll.getPhotos({first:1234})`がエラーになってしまいます。また、これはiOSのみで発生します。エラー文を見た感じ、optionとしてassetTypeに何かしら指定すれば良さそうです。ただ、ドキュメントを見…