初めての開発現場を経験して

PHOTOGRAPHY ADVICE I GIVE EVERY TIME 0. 目次 1. はじめに 皆さんこんにちは。久しぶりの投稿です。 今回は初めて開発系のプロジェクトを経験しました。アプリやソフトウェアを作るほどのがっつりとした開発プロジェクトではなくサーバで定期的に実行されるbatやスクリプトの開発プロジェクトでしたが、それでもインフラ系のプロジェクトとは異なり、かなり苦労したので、その中で経験し感じたことを備忘録として残しておきます。 ただ具体的な言語がどうとかフレームワークとかの話というよりは、こんなことが大事だったなみたいな話です。 チーム体制については、4,5人のチームでほとんど開発経験のある方はおらず、インフラを主に扱っている方々でした。(誰もコードなんて書けん、、みたいな状況です。) 2. 担当した工程と経験したこと 簡単にプロジェクト内の工程でどんなことを経験したか説明します。 後悔した点やこんなことすれば良かった点については後ほど説明します。 ■担当した工程 ■詳細設計 私がまず担当した工程は、詳細設計でした。基本設計と機能設計はほぼ終わっていました。 作業としては、お客様の要件を満たすために設計された機能を実装するためのプロセスや処理をドキュメントに書き起こす作業です。 インフラ系のプロジェクトの詳細設計書は、サーバやソフトウェアのパラメータ記載することが、多いイメージですが、開発系の詳細設計書は少し異なります。フロー図などを用いて、開始処理から処理処理までのプロセスの流れを詳細に記載する必要があります。 フロー図については、以下のような図を指します。 幸いにも機能自体が複雑ではなかったこともあり、フロー図の作成することはできました。 このフロー図の作成でプログラムの構造を整理することができ、ロジックや考え方が少し身に付きました。 プログラムにおいては、処理Aが起きた後に処理Bが発生しなければいけないとか、この処理がループ処理に含まれてはいけないとか処理全体の整合性が保たれなければバグとなってしまうのです。 フロー図の作成は、システムの全体を理解するために構成図を作ったりすることと同じように感じました。 ■コーディング 詳細設計が完了したら設計書を元にコーディングしていきます。全然コマンドを知らないため、何を使えば良いの調べるのにかなり苦労しました笑、この処理はどのコマンドを使えば良いのだろうと一生懸命考えてました。 ただ一から調べて実装するには作業時間の兼ね合いもありますし、限界があったため、生成AIを活用していました。 この機能を実装したいのでコマンドの使用例を教えてほしいと質問すれば大体は教えてくれますし、実際にプログラミングしてスクリプトとして、例を出してくれたりします。他にも既にコーディングされたものでどんな処理を行っているのか不明な箇所があった場合には、その部分を尋ねると説明してくれたりもします。 生成AIはかなり重宝しました。 ↓Microsoft edgeで使用できる「Copilot」を用いた例 ■単体試験、結合試験 単体試験と結合試験では、試験仕様書の作成と試験実施しました。試験仕様書の項目としては、テスト対象、観点、条件、手順、確認結果等があります。バグの洗い出しとその改修が目的になるため、漏れがないように詳細に記載する必要があります。仕様書は網羅的に試験観点を洗い出さなければいけないため、時間がかかりました。大まかに正常な場合(動作が正しく行われる場合)と異常な場合(意図しない動作の場合)の2パターンがあり、それぞれの試験でも細かい条件で試験結果が変わり、検討しなければいけない事が多いため、マトリクス図を活用しました。さらには試験条件によっては、現実的に起こりえないものなどがあったりするので、必要のない試験の洗い出しもしなければいけません。 試験では、実際に作ったものを仕様書の条件に沿って実行して、動作結果を記録していきます。エビデンスをどうするかという点について、かなり苦労しましたが、次のコラムで説明したいと思います。 3. 全体を振り返ってみて 全体を振り返ってみて、大事だと感じたポイントを紹介します。 ■生成AIの活用について 生成AIは、これまでの仕事ではあまり活用する場面が少なく使ってこなかったのですが、知識が全くない状態から調査しなければいけない問題が多かったこともあり、かなり活用しました。よほど専門的な分野でなければ、初歩的な調査にはかなり有用です。

初めての開発現場を経験して2024-06-04T13:39:03+09:00

002_AWS環境におけるパブリックサブネット、プライベートサブネットの作成方法

PHOTOGRAPHY ADVICE I GIVE EVERY TIME 0. 目次 みなさま、こんにちは!今回は2回目の投稿になります!よろしくお願いします! 【今回の内容】 今回は、AWS環境でパブリックサブネット、プライベートサブネットの作成方法をご説明していきたいと思います。 上記の2つサブネットはAWSでシステムを構築する際の重要な考え方です。 一般的なインフラ環境では、webサーバなどの公開サーバをパブリックネットワークに配置、DBサーバなど非公開サーバをプライベートネットワークに配置します。 AWS環境で上記の構成しようとした場合どうしたら良いのでしょうか? その疑問が解消できるような説明、環境構築、検証を本記事では行っています!サブネットに関する説明、実際の構築手順の紹介、構築環境での検証を通じて、皆さまの理解を深めることができれば嬉しく思います!是非ご覧ください! 【前提】 AWS環境を所有していること。 ※本検証では一部無料枠を超えたサービスを利用します。もし検証される場合はご注意ください。 1. はじめに 1-1. 全体構成図 本検証で作成する全体構成図になります。検証のためミニマム構成となっていますが、ご確認ください。 1-2.本検証におけるAWSのサービス一覧 本検証の環境構築には主に以下のサービスを使用します。サービスに関する説明は構築手順の前に説明をいれています。 詳しくはAWSドキュメントをご覧ください。 ①VPC Amazon VPC とは? ②サブネット VPC のサブネット ③インターネットゲートウェイ インターネットゲートウェイ ④NATゲートウェイ NAT ゲートウェイ ⑤ルートテーブル ルートテーブル ⑥Elastic

002_AWS環境におけるパブリックサブネット、プライベートサブネットの作成方法2022-11-22T12:03:23+09:00

001_AWS環境へのP2SのVPN接続

PHOTOGRAPHY ADVICE I GIVE EVERY TIME 0. 目次 【今回の内容】 第一回目の投稿になります。よろしくお願いいたします! 今回は、タイトルの通り、AWS環境にクライアントVPNポイントを構築して、オンプレミスの検証環境のwin10端末からAWS環境へのP2S(ポイント対サイト)のVPN接続を行いました。 その手順のご紹介になります! ■AWSへの接続に関するサービスは2つあります。 ・AWSVPN ※今回の検証で使用 →AWSが提供するVPNを用いた通信サービスになります。 ・AWS Direct Connect →インターネットを介さず、AWSが提供する専用線接続用いた通信サービスになります。 ■AWS環境へのVPN接続のパターンは2つになります。 ・AWSClientVPN接続 P2S接続(ポイント対サイト) ※今回の検証で使用 →個々の端末とAWS環境を接続する方式 ・AWSサイト間VPN接続 S2S接続(サイト対サイト) →オンプレミスの環境とAWS環境を接続する方式 【前提事項】 ・AWS環境でVPC環境が構築されていること ・接続元となるクライアント端末があること →今回の検証ではwin10端末を使用しています。 検証の基本的な流れはAWSドキュメントの以下を参照しています。 クライアント VPN の開始方法 1. 証明書、キーの作成 今回のVPN接続には証明書認証を使った相互認証接続を行います。 簡単に説明すると、接続元と接続先で「あなた接続しようとしているけど信用しても大丈夫ですか?」という確認をお互いに証明書を元に検証してから接続する方式になります。 ※本検証では自己署名での証明書になります。 証明書はAWSドキュメントの通りにOpenVPN easy-rsa ユーティリティを使用して作成します。この証明書がVPNエンドポイントクライアントを作成する際に必要になります。 1-1. OpenVPN easy-rsa ユーティリティのダウンロード

001_AWS環境へのP2SのVPN接続2022-11-22T12:03:14+09:00
Go to Top