JP2019128617A - Information processing system, information processing method, and program - Google Patents

Information processing system, information processing method, and program Download PDF

Info

Publication number
JP2019128617A
JP2019128617A JP2018007716A JP2018007716A JP2019128617A JP 2019128617 A JP2019128617 A JP 2019128617A JP 2018007716 A JP2018007716 A JP 2018007716A JP 2018007716 A JP2018007716 A JP 2018007716A JP 2019128617 A JP2019128617 A JP 2019128617A
Authority
JP
Japan
Prior art keywords
information
software
server
procedure
container
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Granted
Application number
JP2018007716A
Other languages
Japanese (ja)
Other versions
JP7067933B2 (en
Inventor
洋平 柏村
Yohei Kashiwamura
洋平 柏村
加藤 稔
Minoru Kato
稔 加藤
尚紀 都竹
Naoki Tsutake
尚紀 都竹
美帆 永井
Miho Nagai
美帆 永井
淳 笠原
Atsushi Kasahara
淳 笠原
孝光 横井
Takamitsu Yokoi
孝光 横井
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
NTT Comware Corp
Original Assignee
NTT Comware Corp
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by NTT Comware Corp filed Critical NTT Comware Corp
Priority to JP2018007716A priority Critical patent/JP7067933B2/en
Publication of JP2019128617A publication Critical patent/JP2019128617A/en
Application granted granted Critical
Publication of JP7067933B2 publication Critical patent/JP7067933B2/en
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Landscapes

  • Stored Programmes (AREA)

Abstract

To reduce procedural mistakes and shorten a construction time when constructing a software development environment.SOLUTION: Provided is an information processing system capable of constructing a development environment for software corresponding to each of a plurality of tenants that indicates a contract of receiving the supply of a computer resource, the information processing system comprising: a procedure acquisition unit for acquiring procedure information which stipulates a procedure for installing software utilizing container type virtualization for constructing a virtual area in a common operating system, and which meets a request from a user corresponding to a tenant; and a construction processing unit for causing a test server corresponding to the tenant to install software for development environments at least.SELECTED DRAWING: Figure 1

Description

本発明は、情報処理システム、情報処理方法、及びプログラムに関する。   The present invention relates to an information processing system, an information processing method, and a program.

近年、ユーザの要求に応じてコンピュータリソースを提供する仮想環境を構築する技術が知られている(例えば、特許文献1を参照)。特許文献1に記載の技術では、ユーザの性能要求に応じて、例えば、ベアメタルサーバ、コンテナ型仮想サーバ、仮想マシンのなかからサーバ種別を選択して、ユーザごとの仮想環境を構築する。   BACKGROUND In recent years, a technology for constructing a virtual environment that provides computer resources in response to a user's request has been known (see, for example, Patent Document 1). In the technology described in Patent Document 1, according to the user's performance request, for example, a server type is selected from among bare metal servers, container virtual servers, and virtual machines, and a virtual environment for each user is constructed.

国際公開第2016/167086号International Publication No. 2016/167086

しかしながら、上述した従来技術では、ソフトウェアの開発環境を構築するためには、上述のように構築された試験サーバに、例えば、開発用のツール等を手動でインストールため、専門的な知識が必要であった。そのため、従来技術では、ソフトウェアの開発環境の構築に、時間が掛かったり、構築の手順ミスが生じて、開発環境を上手く構築できなかったりすることがあった。   However, in the above-described conventional technology, in order to construct a software development environment, for example, a development tool or the like is manually installed on the test server constructed as described above, and thus specialized knowledge is required. there were. Therefore, in the prior art, it took time to build a software development environment, or a procedure error in the construction occurred, and the development environment could not be built successfully.

本発明は、上記問題を解決すべくなされたもので、その目的は、ソフトウェアの開発環境を構築する際に、手順ミスを低減し、且つ、構築時間を短縮することができる情報処理システム、情報処理方法、及びプログラムを提供することにある。   The present invention has been made to solve the above-mentioned problems, and its purpose is to reduce an error in the procedure when constructing a software development environment, and an information processing system and information capable of shortening the construction time. It is providing a processing method and program.

上記問題を解決するために、本発明の一態様は、コンピュータリソースの提供を受ける契約を示す複数のテナントそれぞれに対応したソフトウェアの開発環境を構築可能な情報処理システムであって、共通のオペレーティングシステム上に仮想領域を構築するコンテナ型仮想化を利用してソフトウェアをインストールするための手順を規定した手順情報であって、前記テナントに対応する利用者からの要求に応じた手順情報を取得する手順取得部と、前記手順取得部によって取得した前記手順情報に基づいて、前記テナントに対応する試験サーバに、少なくとも開発環境用のソフトウェアをインストールさせる構築処理部とを備えることを特徴とする情報処理システムである。   In order to solve the above problems, an aspect of the present invention is an information processing system capable of constructing a software development environment corresponding to each of a plurality of tenants indicating a contract for receiving provision of computer resources, and a common operating system Procedure information that is procedure information that defines a procedure for installing software using container-type virtualization that builds a virtual area on top, and that corresponds to a request from a user corresponding to the tenant An information processing system comprising: an acquisition unit; and a construction processing unit configured to install at least software for a development environment in a test server corresponding to the tenant based on the procedure information acquired by the procedure acquisition unit. It is.

また、本発明の一態様は、上記の情報処理システムにおいて、前記ソフトウェアの開発環境を構築するためのソフトウェア及び前記手順情報を記憶する共通サーバを備え、前記手順取得部は、前記利用者からの要求に応じた前記手順情報を前記共通サーバから取得し、前記構築処理部は、前記手順情報に基づいて、前記試験サーバに、前記共通サーバが記憶する前記ソフトウェアをインストールさせることを特徴とする。   Further, according to one aspect of the present invention, in the above-described information processing system, the information processing system includes software for constructing the development environment of the software and a common server storing the procedure information, and the procedure acquisition unit receives the information from the user. The procedure information according to a request is acquired from the common server, and the construction processing unit causes the test server to install the software stored in the common server based on the procedure information.

また、本発明の一態様は、上記の情報処理システムにおいて、前記手順情報には、予め検証された前記ソフトウェアのバージョン及び組合せにより前記開発環境用のソフトウェアをインストールする手順が規定されており、前記構築処理部は、前記手順情報に基づいて、前記バージョン及び前記組合せが検証済みの前記開発環境用のソフトウェアをインストールさせることを特徴とする。   Further, according to one aspect of the present invention, in the above information processing system, a procedure for installing software for the development environment is defined in the procedure information according to a version and combination of the software verified in advance. The construction processing unit is configured to install the software for the development environment whose version and the combination have been verified based on the procedure information.

また、本発明の一態様は、上記の情報処理システムにおいて、前記手順取得部と、前記構築処理部とを含み、前記テナントごとに構築された管理サーバを備えることを特徴とする。   Further, according to one aspect of the present invention, in the above-described information processing system, the information processing system includes the procedure acquisition unit and the construction processing unit, and includes a management server constructed for each of the tenants.

また、本発明の一態様は、コンピュータリソースの提供を受ける契約を示す複数のテナントそれぞれに対応したソフトウェアの開発環境を構築可能な情報処理システムの情報処理方法であって、手順取得部が、共通のオペレーティングシステム上に仮想領域を構築するコンテナ型仮想化を利用してソフトウェアをインストールするための手順を規定した手順情報であって、前記テナントに対応する利用者からの要求に応じた手順情報を取得する手順取得ステップと、構築処理部が、前記手順取得ステップによって取得した前記手順情報に基づいて、前記テナントに対応する試験サーバに、少なくとも開発環境用のソフトウェアをインストールさせる構築処理ステップとを含むことを特徴とする情報処理方法である。   Further, one aspect of the present invention is an information processing method of an information processing system capable of constructing a software development environment corresponding to each of a plurality of tenants indicating a contract for receiving provision of computer resources, wherein the procedure acquisition unit is common Procedure information that defines the procedure for installing software using container-type virtualization to construct a virtual area on the operating system, and the procedure information according to the request from the user corresponding to the tenant And a construction processing step of causing the test processing server corresponding to the tenant to install at least software for a development environment based on the procedure information acquired by the procedure acquisition step. This is an information processing method characterized by this.

また、本発明の一態様は、コンピュータリソースの提供を受ける契約を示す複数のテナントそれぞれに対応したソフトウェアの開発環境を構築可能な情報処理システムが有するコンピュータに、共通のオペレーティングシステム上に仮想領域を構築するコンテナ型仮想化を利用してソフトウェアをインストールするための手順を規定した手順情報であって、前記テナントに対応する利用者からの要求に応じた手順情報を取得する手順取得ステップと、前記手順取得ステップによって取得した前記手順情報に基づいて、前記テナントに対応する試験サーバに、少なくとも開発環境用のソフトウェアをインストールさせる構築処理ステップとを実行させるためのプログラムである。   Further, according to one aspect of the present invention, a virtual region is shared on a common operating system in a computer included in an information processing system capable of constructing a software development environment corresponding to each of a plurality of tenants indicating a contract for receiving provision of computer resources. A procedure acquisition step of acquiring procedure information according to a request from a user corresponding to the tenant, which is procedure information defining a procedure for installing software using container-type virtualization to be constructed; It is a program for causing a test server corresponding to the tenant to execute at least a construction processing step of installing software for a development environment based on the procedure information acquired by the procedure acquisition step.

本発明によれば、ソフトウェアの開発環境を構築する際に、手順ミスを低減し、且つ、構築時間を短縮することができる。   According to the present invention, when constructing a software development environment, procedure errors can be reduced and construction time can be shortened.

第1の実施形態による情報処理システムの一例を示すブロック図である。It is a block diagram showing an example of the information processing system by a 1st embodiment. 第1の実施形態におけるテナント情報記憶部のデータ例を示す図である。It is a figure showing an example of data of a tenant information storage part in a 1st embodiment. 第1の実施形態における利用者情報記憶部のデータ例を示す図である。It is a figure which shows the example of data of the user information storage part in 1st Embodiment. 第1の実施形態における仮想マシン情報記憶部のデータ例を示す図である。It is a figure which shows the example of data of the virtual machine information storage part in 1st Embodiment. 第1の実施形態におけるインストーラ情報記憶部のデータ例を示す図である。It is a figure which shows the example of data of the installer information storage part in 1st Embodiment. 第1の実施形態におけるコンテナ情報記憶部のデータ例を示す図である。It is a figure which shows the example of data of the container information storage part in 1st Embodiment. 第1の実施形態におけるプレイブック情報記憶部のデータ例を示す図である。It is a figure which shows the example of data of the playbook information storage part in 1st Embodiment. 第1の実施形態におけるポータルサーバにより表示される表示画面の第1の例を示す図である。It is a figure which shows the 1st example of the display screen displayed by the portal server in 1st Embodiment. 第1の実施形態におけるポータルサーバにより表示される表示画面の第2の例を示す図である。It is a figure which shows the 2nd example of the display screen displayed by the portal server in 1st Embodiment. 第1の実施形態におけるポータルサーバにより表示される表示画面の第3の例を示す図である。It is a figure which shows the 3rd example of the display screen displayed by the portal server in 1st Embodiment. 第1の実施形態におけるポータルサーバにより表示される表示画面の第4の例を示す図である。It is a figure which shows the 4th example of the display screen displayed by the portal server in 1st Embodiment. 第1の実施形態における試験サーバのツールのインストール例を示す図である。It is a figure which shows the example of installation of the tool of the test server in 1st Embodiment. 第1の実施形態における試験サーバへのベアインストール処理の一例を示す図である。It is a figure which shows an example of the bear installation process to the test server in 1st Embodiment. 第1の実施形態におけるベアインストールのインストール依頼を生成する処理の一例を示すフローチャートである。It is a flowchart which shows an example of the process which produces | generates the installation request of bare installation in 1st Embodiment. 第1の実施形態における試験サーバへのコンテナを利用したインストール処理の一例を示す図である。It is a figure which shows an example of the installation process using the container to the test server in 1st Embodiment. 第1の実施形態におけるコンテナを利用したインストール依頼を生成する処理の一例を示すフローチャートである。It is a flow chart which shows an example of processing which generates an installation demand using a container in a 1st embodiment. 第1の実施形態におけるコンテナの制御処理の一例を示す図である。It is a figure showing an example of control processing of a container in a 1st embodiment. 第2の実施形態による情報処理システムの一例を示すブロック図である。It is a block diagram showing an example of the information processing system by a 2nd embodiment.

以下、本発明の一実施形態による情報処理システム及び情報処理方法について、図面を参照して説明する。   Hereinafter, an information processing system and an information processing method according to an embodiment of the present invention will be described with reference to the drawings.

[第1の実施形態]
図1は、第1の実施形態による情報処理システム1の一例を示すブロック図である。
図1に示すように、情報処理システム1は、利用者端末装置10と、ポータルサーバ20と、共通サーバ30と、複数のテナント60のそれぞれが有する管理サーバ40と、試験サーバ50とを備えている。本実施形態において、情報処理システム1は、複数のテナント60それぞれに対応したソフトウェアの開発環境を構築可能なシステムである。
[First Embodiment]
FIG. 1 is a block diagram illustrating an example of an information processing system 1 according to the first embodiment.
As illustrated in FIG. 1, the information processing system 1 includes a user terminal device 10, a portal server 20, a common server 30, a management server 40 included in each of a plurality of tenants 60, and a test server 50. Yes. In the present embodiment, the information processing system 1 is a system capable of constructing a software development environment corresponding to each of the plurality of tenants 60.

なお、テナント60は、コンピュータリソースの提供を受ける契約を示し、テナント60−1、テナント60−2、・・・は、それぞれ異なる契約を示している。また、本実施形態において、テナント60−1、テナント60−2、・・・は、情報処理システム1が備える任意のテナントを示す場合、又は特に区別しない場合には、テナント60として説明する。   The tenant 60 indicates a contract for receiving provision of computer resources, and the tenant 60-1, the tenant 60-2, and so on indicate different contracts. In the present embodiment, the tenant 60-1, the tenant 60-2, and so on will be described as the tenant 60 when indicating an arbitrary tenant provided in the information processing system 1 or when not making a distinction.

また、本実施形態において、管理サーバ40−1、管理サーバ40−2、・・・は、情報処理システム1が備える任意の管理サーバを示す場合、又は特に区別しない場合には、管理サーバ40として説明する。同様に、試験サーバ51−1、試験サーバ52−1、・・・、及び試験サーバ51−2、試験サーバ52−2、・・・は、情報処理システム1が備える任意の試験サーバを示す場合、又は特に区別しない場合には、試験サーバ50として説明する。また、ネットワークNW2−1、ネットワークNW2−2、・・・は、情報処理システム1が備えるテナント60内のネットワークを示す場合、又は特に区別しない場合には、ネットワークNW2として説明する。   Moreover, in the present embodiment, when the management server 40-1, the management server 40-2,... Indicate any management server included in the information processing system 1, or when not particularly distinguished, as the management server 40. explain. Similarly, when the test server 51-1, the test server 52-1, ..., and the test server 51-2, the test server 52-2, ... indicate any test server included in the information processing system 1. Or, in the case where no distinction is made, the test server 50 will be described. In addition, the network NW2-1, the network NW2-2,... Are described as the network NW2 when they indicate the networks in the tenant 60 included in the information processing system 1 or when they are not particularly distinguished.

また、利用者端末装置10と、ポータルサーバ20と、共通サーバ30と、管理サーバ40とは、ネットワークNW1に接続されている。ここで、ネットワークNW1は、複数のテナント60に対応する複数の利用者(契約者)の利用者端末装置10が、接続可能なネットワークであり、例えば、WAN(Wide Area Network)、グローバルエリアネットワークなどである。   The user terminal device 10, the portal server 20, the common server 30, and the management server 40 are connected to the network NW1. Here, the network NW1 is a network to which user terminal devices 10 of a plurality of users (contractors) corresponding to a plurality of tenants 60 can connect, for example, WAN (Wide Area Network), global area network, etc. It is.

また、各テナント60において、管理サーバ40と、試験サーバ50とは、ネットワークNW2に接続されている。ここで、ネットワークNW2は、各テナント内のローカルなネットワークである。   In each tenant 60, the management server 40 and the test server 50 are connected to the network NW2. Here, the network NW2 is a local network in each tenant.

利用者端末装置10は、例えば、PC(パーソナルコンピュータ)などのコンピュータ装置であり、各テナント60に対応する利用者が利用する端末装置である。利用者端末装置10は、ネットワークNW1を介して、ポータルサーバ20と接続し、テナント60へのソフトウェアの開発環境、及びテナント60の管理などの操作を行う。また、利用者端末装置10は、入力部11と、表示部12と、端末制御部13とを備えている。   The user terminal device 10 is, for example, a computer device such as a PC (personal computer), and is a terminal device used by a user corresponding to each tenant 60. The user terminal device 10 is connected to the portal server 20 via the network NW1 and performs operations such as a software development environment for the tenant 60 and management of the tenant 60. In addition, the user terminal device 10 includes an input unit 11, a display unit 12, and a terminal control unit 13.

入力部11は、例えば、キーボードやタッチパネル、マウスなどの入力装置であり、利用者からの要求であるソフトウェアの開発環境の要求情報などを入力情報として受け付ける。入力部11は、受け付けた入力情報を端末制御部13に出力する。
表示部12(出力部の一例)は、例えば、液晶ディスプレイ装置などであり、各種情報を表示する。表示部12は、例えば、ポータルサーバ20から提供される選択肢や、要求情報の選択肢及び入力を行う際の操作画面やメニュー画面などを表示する。
The input unit 11 is, for example, an input device such as a keyboard, a touch panel, or a mouse, and accepts, as input information, request information of a software development environment that is a request from a user. The input unit 11 outputs the received input information to the terminal control unit 13.
The display unit 12 (an example of an output unit) is a liquid crystal display device, for example, and displays various types of information. The display unit 12 displays, for example, an option provided from the portal server 20, an option for request information, and an operation screen and a menu screen for performing input.

端末制御部13は、例えば、CPU(Central Processing Unit)などを含むプロセッサであり、利用者端末装置10を統括的に制御する。端末制御部13は、ソフトウェアの開発環境の構築や、テナントの管理を行う際に、入力部11が受け付けた入力情報を、ネットワークNW1を介して、ポータルサーバ20に送信する。また、端末制御部13は、ポータルサーバ20を介して、ポータルサーバ20から受信したメニュー画面及び操作画面などの表示データを受信して、当該メニュー画面及び当該操作画面などを表示部12に表示させる。   The terminal control unit 13 is a processor including, for example, a CPU (Central Processing Unit) and the like, and controls the user terminal device 10 in a centralized manner. The terminal control unit 13 transmits the input information received by the input unit 11 to the portal server 20 via the network NW1 when constructing a software development environment and managing a tenant. In addition, the terminal control unit 13 receives display data such as a menu screen and an operation screen received from the portal server 20 via the portal server 20, and causes the display unit 12 to display the menu screen and the operation screen. .

ポータルサーバ20は、情報処理システム1を利用するためのポータルサイトであり、各種メニュー画面及び操作画面などの表示データを、ネットワークNW1を介して、利用者端末装置10に送信して、各種メニュー画面及び操作画面を利用者端末装置10の表示部12に表示させる。また、ポータルサーバ20は、利用者端末装置10からネットワークNW1を介して受信した入力情報に基づいて、各種処理を実行する。   The portal server 20 is a portal site for using the information processing system 1, and transmits display data such as various menu screens and operation screens to the user terminal device 10 via the network NW1 to perform various menu screens. The operation screen is displayed on the display unit 12 of the user terminal device 10. The portal server 20 also executes various processes based on input information received from the user terminal device 10 via the network NW1.

例えば、ポータルサーバ20は、利用者端末装置10を介して利用者から、ソフトウェアの開発環境の要求情報を受け付け、受け付けた要求情報に基づいて、インストール依頼を生成する。ポータルサーバ20は、開発環境用のソフトウェアを、利用者のテナント60に対応する試験サーバ50に、例えば、共通のオペレーティングシステム上に仮想領域を構築するコンテナ型仮想化を利用してインストールさせるインストール依頼を生成する。ポータルサーバ20は、生成したインストール依頼を、利用者のテナント60に対応する管理サーバ40に送信する。なお、以下の説明において、開発環境用のソフトウェアを、開発用のツール又は単にツールと呼ぶことがある。   For example, the portal server 20 receives the request information of the software development environment from the user via the user terminal device 10, and generates an installation request based on the received request information. The portal server 20 requests installation of software for a development environment on the test server 50 corresponding to the user's tenant 60, for example, by using container-type virtualization for constructing a virtual area on a common operating system. Generate The portal server 20 transmits the generated installation request to the management server 40 corresponding to the user tenant 60. In the following description, software for a development environment may be called a development tool or simply a tool.

また、ポータルサーバ20は、例えば、試験サーバ50にインストールしているソフトウェアを制御する制御指示を、利用者端末装置10を介して利用者から受け付ける。ポータルサーバ20は、制御指示に基づく制御依頼を、利用者のテナント60に対応する管理サーバ40に送信する。
また、ポータルサーバ20は、ポータル記憶部21と、ポータル制御部22とを備えている。
Further, the portal server 20 receives, for example, a control instruction for controlling software installed in the test server 50 from the user via the user terminal device 10. The portal server 20 transmits a control request based on the control instruction to the management server 40 corresponding to the tenant 60 of the user.
The portal server 20 includes a portal storage unit 21 and a portal control unit 22.

ポータル記憶部21は、ポータルサーバ20が利用する各種情報を記憶する。ポータル記憶部21は、例えば、テナント情報記憶部211と、利用者情報記憶部212と、メニュー情報記憶部213と、仮想マシン情報記憶部214と、インストーラ情報記憶部215と、コンテナ情報記憶部216と、プレイブック情報記憶部217とを備えている。   The portal storage unit 21 stores various information used by the portal server 20. The portal storage unit 21 includes, for example, a tenant information storage unit 211, a user information storage unit 212, a menu information storage unit 213, a virtual machine information storage unit 214, an installer information storage unit 215, and a container information storage unit 216. And a playbook information storage unit 217.

テナント情報記憶部211は、情報処理システム1が登録(契約)しているテナントの情報を記憶する。テナント情報記憶部211は、例えば、図2に示すように、テナントを識別するテナントID(テナント識別情報)と、テナントに関連する各種情報とを対応付けて記憶する。   The tenant information storage unit 211 stores information on tenants registered (contracted) by the information processing system 1. For example, as illustrated in FIG. 2, the tenant information storage unit 211 stores a tenant ID (tenant identification information) for identifying a tenant and various types of information related to the tenant in association with each other.

図2は、本実施形態におけるテナント情報記憶部211のデータ例を示す図である。
図2に示すように、テナント情報記憶部211は、「テナントID」と、「契約グループID」と、「プロジェクトID」と、「テナント名」とを対応付けて記憶する。ここで、「テナントID」は、テナント識別情報の一例であり、「契約グループID」は、例えば、テナントを契約した組織、所属などの識別情報であり、「プロジェクトID」は、例えば、当該テナントにより開発するソフトウェアのプロジェクトの識別情報である。
FIG. 2 is a diagram illustrating an example of data in the tenant information storage unit 211 in the present embodiment.
As illustrated in FIG. 2, the tenant information storage unit 211 stores “tenant ID”, “contract group ID”, “project ID”, and “tenant name” in association with each other. Here, the “tenant ID” is an example of tenant identification information, the “contract group ID” is, for example, identification information of an organization, affiliation, etc. that has contracted the tenant, and the “project ID” is, for example, the tenant Is the identification information of the project of software to be developed.

また、「契約グループID」、「プロジェクトID」、及び「テナント名」は、テナントに関連する各種情報の一例である。また、テナントに関連する各種情報には、これらの情報の他に、例えば、契約日(申込日)に関する日時情報や、テナントのボリューム容量(容量情報)、変更(更新)に関する日時情報などが含まれてもよい。
図2に示す例では、「テナントID」が“T0001”に対応するテナントは、「契約グループID」が“G0001”であり、「プロジェクトID」が“PJ001”であり、「テナント名」が“XXXX”であることを示している。
Also, “contract group ID”, “project ID”, and “tenant name” are examples of various information related to a tenant. In addition to the above information, the various information related to the tenant includes, for example, date and time information on the contract date (application date), volume capacity of the tenant (capacity information), and date and time information on change (update) May be.
In the example shown in FIG. 2, for the tenant whose "tenant ID" corresponds to "T0001", the "contract group ID" is "G0001", the "project ID" is "PJ001", and the "tenant name" is " XXXX ".

図1の説明に戻り、利用者情報記憶部212は、情報処理システム1を利用する利用者(ユーザ)の情報を記憶する。利用者情報記憶部212は、例えば、図3に示すように、利用者を識別するユーザID(利用者識別情報)と、利用者に関連する各種情報とを対応付けて記憶する。   Returning to the description of FIG. 1, the user information storage unit 212 stores information on a user (user) who uses the information processing system 1. For example, as shown in FIG. 3, the user information storage unit 212 associates and stores a user ID (user identification information) for identifying a user and various information related to the user.

図3は、本実施形態における利用者情報記憶部212のデータ例を示す図である。
図3に示すように、利用者情報記憶部212は、「ユーザID」と、「契約グループID」と、「ユーザ名」と、「ログイン情報」と、「テナントID」とを対応付けて記憶する。ここで、「ユーザID」は、利用者識別情報の一例であり、「契約グループID」、及び「テナントID」は、例えば、当該利用者に対応する「契約グループID」、及び「テナントID」を示している。また、「ユーザ名」は、利用者の名前を示しており、「ログイン情報」は、パスワードなどのポータルサーバ20にログインする際の認証情報などを示している。
FIG. 3 is a diagram illustrating an example of data in the user information storage unit 212 in the present embodiment.
As illustrated in FIG. 3, the user information storage unit 212 stores “user ID”, “contract group ID”, “user name”, “login information”, and “tenant ID” in association with each other. To do. Here, the "user ID" is an example of user identification information, and the "contract group ID" and the "tenant ID" are, for example, the "contract group ID" and the "tenant ID" corresponding to the user. Is shown. “User name” indicates the name of the user, and “Login information” indicates authentication information when logging in to the portal server 20 such as a password.

また、「契約グループID」、「ユーザ名」、「ログイン情報」、及び「テナントID」は、利用者に関連する各種情報の一例である。また、利用者に関連する各種情報には、これらの情報の他に、例えば、登録日(申込日)、変更日(更新日)などの日時情報、利用権限情報などが含まれてもよい。
図3に示す例では、「ユーザID」が“U0001”に対応する利用者は、「契約グループID」が“G0001”であり、「ユーザ名」が“○○○○”であり、「ログイン情報」が“XXXXXX”であり、対応する「テナントID」が“T0001”であることを示している。
The “contract group ID”, “user name”, “login information”, and “tenant ID” are examples of various types of information related to the user. In addition to these pieces of information, the various types of information related to the user may include date information such as a registration date (application date) and a change date (update date), usage authority information, and the like.
In the example shown in FIG. 3, the user whose "user ID" corresponds to "U0001" is that "contract group ID" is "G0001" and "user name" is "○○○○", and "login""Information" indicates "XXXXXX" and the corresponding "tenant ID" indicates "T0001".

再び、図1の説明に戻り、メニュー情報記憶部213は、ポータルサーバ20が利用者端末装置10の表示部12に表示させる操作画面やメニュー画面の情報や、選択可能な入力情報などを記憶する。   Returning to the description of FIG. 1 again, the menu information storage unit 213 stores information on operation screens and menu screens that the portal server 20 displays on the display unit 12 of the user terminal device 10, selectable input information, and the like. .

仮想マシン情報記憶部214は、情報処理システム1に構築されている仮想マシンの情報を記憶する。仮想マシン情報記憶部214は、例えば、図4に示すように、仮想マシンを識別するマシンID(仮想マシン識別情報)と、仮想マシンに関連する各種情報とを対応付けて記憶する。   The virtual machine information storage unit 214 stores information on virtual machines built in the information processing system 1. For example, as illustrated in FIG. 4, the virtual machine information storage unit 214 associates and stores a machine ID (virtual machine identification information) for identifying a virtual machine and various information related to the virtual machine.

図4は、本実施形態における仮想マシン情報記憶部214のデータ例を示す図である。
図4に示すように、仮想マシン情報記憶部214は、「マシンID」と、「マシン種別」と、「マシン名」と、「IPアドレス」と、「テナントID」と、「サーバタイプ」と、「状態情報」とを対応付けて記憶する。ここで、「マシンID」は、仮想マシン識別情報の一例であり、「テナントID」は、例えば、当該仮想マシンに対応する「テナントID」を示している。
FIG. 4 is a diagram illustrating a data example of the virtual machine information storage unit 214 in the present embodiment.
As illustrated in FIG. 4, the virtual machine information storage unit 214 includes “machine ID”, “machine type”, “machine name”, “IP address”, “tenant ID”, and “server type”. And “state information” are stored in association with each other. Here, “machine ID” is an example of virtual machine identification information, and “tenant ID” indicates, for example, “tenant ID” corresponding to the virtual machine.

また、「マシン名」は、仮想マシンの名前を示しており、「マシン種別」は、例えば、“試験サーバ”、“管理サーバ”、などの情報処理システム1内における仮想マシンの種別を示している。また、「IPアドレス」は、仮想マシンに割り当てられているIP(Internet Protocol)アドレスを示し、「状態情報」は、例えば、“起動中”、“停止中”などの仮想マシンの起動状態を示している。また、「サーバタイプ」は、インストール可能なソフトウェア及びコンテナを判定するためのタイプコード(タイプ情報)を示している。   Also, “machine name” indicates the name of the virtual machine, and “machine type” indicates the type of virtual machine in the information processing system 1 such as “test server” or “management server”, for example. There is. Also, “IP address” indicates an IP (Internet Protocol) address assigned to the virtual machine, and “state information” indicates, for example, a start state of the virtual machine such as “starting” or “stopping”. ing. “Server type” indicates a type code (type information) for determining installable software and containers.

また、「マシン種別」、「マシン名」、「IPアドレス」、「テナントID」、「サーバタイプ」、及び「状態情報」は、仮想マシンに関連する各種情報の一例である。また、仮想マシンに関連する各種情報には、これらの情報の他に、例えば、登録日(申込日)、変更日(更新日)などの日時情報、上述したプロジェクトIDなどが含まれてもよい。
図4に示す例では、「マシンID」が“M001”に対応する仮想マシンは、「マシン種別」が“試験サーバ”であり、「マシン名」が“TEST”であり、「IPアドレス」が“XX.XXX.XXX.XX”であり、対応する「テナントID」が“T0001”であることを示している。また、「状態情報」は、仮想マシンが“起動中”であることを示し、「サーバタイプ」が“01”であることを示している。
Also, “machine type”, “machine name”, “IP address”, “tenant ID”, “server type”, and “state information” are examples of various types of information related to virtual machines. In addition to these pieces of information, the various types of information related to the virtual machine may include, for example, date and time information such as a registration date (application date) and a change date (update date), the above-described project ID, and the like. .
In the example shown in FIG. 4, the virtual machine corresponding to the "machine ID" is "M001", the "machine type" is "test server", the "machine name" is "TEST", and the "IP address" is “XX.XXX.XXX.XX”, indicating that the corresponding “tenant ID” is “T0001”. Also, “state information” indicates that the virtual machine is “starting up”, and indicates that “server type” is “01”.

再び、図1の説明に戻り、インストーラ情報記憶部215は、情報処理システム1においてベアインストール可能なツールのインストールに関する情報を記憶する。ここで、ツールとは、例えば、ソフトウェアの開発に必要な各種アプリケーションツール(ソフトウェア)などのことである。インストーラ情報記憶部215は、例えば、図5に示すように、ツールを識別するツールID(ソフトウェア識別情報)と、ツールのインストーラに関連する各種情報とを対応付けて記憶する。   Referring back to FIG. 1 again, the installer information storage unit 215 stores information on the installation of the bare installable tool in the information processing system 1. Here, the tool is, for example, various application tools (software) required for software development. For example, as shown in FIG. 5, the installer information storage unit 215 stores a tool ID (software identification information) for identifying a tool in association with various information related to the installer of the tool.

図5は、本実施形態におけるインストーラ情報記憶部215のデータ例を示す図である。
図5に示すように、インストーラ情報記憶部215は、「ツールID」と、「インストーラ名」と、「バージョン情報」と、「サーバタイプ」と、「プレイブックID」とを対応付けて記憶する。ここで、「ツールID」は、ベアインストール可能なツールのソフトウェア識別情報の一例であり、「インストーラ名」は、例えば、当該ツールをインストールするためのインストーラの名称を示している。また、「バージョン情報」は、ツールのバージョンを示し、「プレイブックID」は、当該ツールをインストールするために使用するプレイブック(Playbook)を識別する識別情報を示している。また、「サーバタイプ」は、インストール可能な仮想マシンのタイプを示している。なお、プレイブックとは、ソフトウェアをインストールするための手順を規定した手順情報(手順ファイル)を示している。
FIG. 5 is a diagram illustrating an example of data in the installer information storage unit 215 according to the present embodiment.
As illustrated in FIG. 5, the installer information storage unit 215 stores “tool ID”, “installer name”, “version information”, “server type”, and “playbook ID” in association with one another. . Here, “tool ID” is an example of software identification information of a tool that can be barely installed, and “installer name” indicates, for example, the name of an installer for installing the tool. Also, “version information” indicates the version of the tool, and “playbook ID” indicates identification information that identifies a playbook (Playbook) used to install the tool. The “server type” indicates the type of virtual machine that can be installed. Note that the playbook indicates procedure information (procedure file) that defines a procedure for installing software.

また、「インストーラ名」、「バージョン情報」、「サーバタイプ」、及び「プレイブックID」は、ツールのインストーラに関連する各種情報の一例である。また、ツールのインストーラに関連する各種情報には、これらの情報の他に、例えば、作成日時、更新日時などの日時情報、アイコン名などが含まれてもよい。
図5に示す例では、「ツールID」が“INS0001”に対応するインストーラは、「インストーラ名」が“ABCD”であり、「バージョン情報」が“1.00”であることを示している。また、「サーバタイプ」が“01”であり、「プレイブックID」が“PB0001”であることを示している。
The “installer name”, “version information”, “server type”, and “playbook ID” are examples of various types of information related to the tool installer. In addition to the above information, the various information related to the installer of the tool may include, for example, date and time information such as creation date and time, update date and time, an icon name, and the like.
In the example shown in FIG. 5, the installer corresponding to the "tool ID" indicates that the "installer name" is "ABCD" and the "version information" is "1.00". Also, it indicates that the “server type” is “01” and the “playbook ID” is “PB0001”.

再び、図1の説明に戻り、コンテナ情報記憶部216は、情報処理システム1においてコンテナ型仮想技術(以下、単にコンテナと言う場合がある)を利用したツールのインストールに関する情報(コンテナ情報)を記憶する。なお、コンテナの詳細については、後述する。コンテナ情報記憶部216は、例えば、図6に示すように、コンテナを識別するコンテナID(コンテナ識別情報)と、コンテナに関連する各種情報とを対応付けて記憶する。   Returning to the description of FIG. 1 again, the container information storage unit 216 stores information (container information) related to the installation of a tool using container-type virtual technology (hereinafter, may be simply referred to as a container) in the information processing system 1 Do. The details of the container will be described later. For example, as shown in FIG. 6, the container information storage unit 216 stores a container ID (container identification information) for identifying a container in association with various information related to the container.

図6は、本実施形態におけるコンテナ情報記憶部216のデータ例を示す図である。
図6に示すように、コンテナ情報記憶部216は、「コンテナID」と、「イメージ名」と、「バージョン情報」と、「ポート情報」と、「サーバタイプ」と、「プレイブックID」とを対応付けて記憶する。ここで、「コンテナID」は、コンテナ識別情報の一例であり、「イメージ名」は、例えば、当該コンテナをインストールするためのコンテナイメージの名称を示している。また、「バージョン情報」は、コンテナイメージのバージョンを示し、「ポート情報」は、プロトコルの種別及び当該コンテナがデフォルトで使用するポート番号を示し、「プレイブックID」は、当該コンテナをインストールするために使用するプレイブックIDを示している。また、「サーバタイプ」は、コンテナをインストール可能な仮想マシンのタイプを示している。なお、「ポート情報」は、コンテナが対応するプロトコルの種別に応じて、複数の情報であってもよい。
FIG. 6 is a diagram illustrating a data example of the container information storage unit 216 in the present embodiment.
As illustrated in FIG. 6, the container information storage unit 216 includes “container ID”, “image name”, “version information”, “port information”, “server type”, and “playbook ID”. Are associated and stored. Here, “container ID” is an example of container identification information, and “image name” indicates, for example, the name of a container image for installing the container. “Version information” indicates the version of the container image, “Port information” indicates the type of protocol and the port number used by the container by default, and “Playbook ID” is for installing the container. Indicates the playbook ID to be used. “Server type” indicates the type of virtual machine on which the container can be installed. The “port information” may be a plurality of pieces of information according to the type of protocol supported by the container.

また、「イメージ名」、「バージョン情報」、「ポート情報」、「サーバタイプ」、及び「プレイブックID」は、コンテナに関連する各種情報の一例である。また、コンテナに関連する各種情報には、これらの情報の他に、例えば、作成日時、更新日時などの日時情報、アイコン名などが含まれてもよい。
図6に示す例では、「コンテナID」が“CN0001”に対応する「イメージ名」が“XXXX”であり、「バージョン情報」が“1.00”であることを示している。また、「ポート情報」が“HTTP:80、SSH:22”あることを示している。また、「サーバタイプ」が“01”であり、「プレイブックID」が“PB0002”であることを示している。
In addition, “image name”, “version information”, “port information”, “server type”, and “playbook ID” are examples of various types of information related to containers. In addition to these pieces of information, for example, various types of information related to the container may include date and time information such as creation date and time, update date and time, icon names, and the like.
In the example illustrated in FIG. 6, “image name” corresponding to “CN0001” as “container ID” is “XXXX”, and “version information” is “1.00”. It also indicates that “port information” is “HTTP: 80, SSH: 22”. Also, it indicates that the “server type” is “01” and the “playbook ID” is “PB0002”.

再び、図1の説明に戻り、プレイブック情報記憶部217は、情報処理システム1において、インストールに使用するプレイブックに関する情報(プレイブック情報)を記憶する。プレイブック情報記憶部217は、例えば、図7に示すように、プレイブックを識別するプレイブックID(プレイブック識別情報)と、プレイブックに関連する各種情報とを対応付けて記憶する。   Referring back to FIG. 1 again, the playbook information storage unit 217 stores information (playbook information) on a playbook used for installation in the information processing system 1. For example, as shown in FIG. 7, the playbook information storage unit 217 associates and stores a playbook ID (playbook identification information) for identifying a playbook and various information related to the playbook.

図7は、本実施形態におけるプレイブック情報記憶部217のデータ例を示す図である。
図7に示すように、プレイブック情報記憶部217は、「プレイブックID」と、「ファイル名」と、「格納場所」とを対応付けて記憶する。ここで、「プレイブックID」は、プレイブック識別情報の一例であり、「ファイル名」は、例えば、当該プレイブックファイルのファイル名を示している。また、「格納場所」は、プレイブックファイルが格納されている場所情報(例えば、リポジトリURL(Uniform Resource Locator)など)を示している。
FIG. 7 is a diagram illustrating a data example of the playbook information storage unit 217 in the present embodiment.
As illustrated in FIG. 7, the playbook information storage unit 217 stores “playbook ID”, “file name”, and “storage location” in association with each other. Here, “playbook ID” is an example of playbook identification information, and “file name” indicates, for example, the file name of the playbook file. The “storage location” indicates location information (for example, repository URL (Uniform Resource Locator)) where the playbook file is stored.

また、「ファイル名」及び「格納場所」は、プレイブックに関連する各種情報の一例である。また、プレイブックに関連する各種情報には、これらの情報の他に、例えば、ブランチ名などが含まれてもよい。
図7に示す例では、「プレイブックID」が“PB0002”に対応する「ファイル名」が“EFGHI”であり、「格納場所」が“XXXX”であることを示している。
The “file name” and “storage location” are examples of various types of information related to the playbook. In addition to these pieces of information, various information related to the playbook may include, for example, a branch name and the like.
The example shown in FIG. 7 indicates that the “file name” corresponding to “playbook ID” “PB0002” is “EFGHI” and the “storage location” is “XXXX”.

なお、インストーラ情報記憶部215、コンテナ情報記憶部216、及びプレイブック情報記憶部217は、後述する共通サーバ30が記憶する情報と同期している。インストーラ情報記憶部215、コンテナ情報記憶部216、及びプレイブック情報記憶部217が記憶する情報は、共通サーバ30が記憶する情報の更新に合わせて、情報処理システム1の運用管理者によって、定期的に更新されるものとする。   The installer information storage unit 215, the container information storage unit 216, and the playbook information storage unit 217 are synchronized with the information stored in the common server 30, which will be described later. The information stored in the installer information storage unit 215, the container information storage unit 216, and the playbook information storage unit 217 is regularly updated by the operation manager of the information processing system 1 in accordance with the update of the information stored in the common server 30. Shall be updated to

また、図1の説明に戻り、ポータル制御部22は、例えば、CPUなどを含むプロセッサであり、ポータルサーバ20を統括的に制御する。ポータル制御部22は、例えば、UI(User Interface)制御部221と、命令実行部222とを備えている。   Further, returning to the explanation of FIG. 1, the portal control unit 22 is a processor including, for example, a CPU and the like, and controls the portal server 20 generally. The portal control unit 22 includes, for example, a UI (User Interface) control unit 221 and an instruction execution unit 222.

UI制御部221(要求受付部の一例)は、ポータルサーバ20のユーザインタフェースを制御する。UI制御部221は、メニュー情報記憶部213が記憶する情報及び利用者端末装置10から取得した入力情報に基づいて、各種表示画面を生成し、ネットワークNW1を介して、各種表示画面を利用者端末装置10の表示部12に表示させる。また、UI制御部221は、ネットワークNW1を介して、利用者端末装置10から取得した入力情報に基づいて、各種処理を実行する。UI制御部221は、例えば、利用者のログイン処理、テナント60の管理処理、仮想マシンの作成、テナント60ごとの管理サーバ40及び試験サーバ50の管理処理(例えば、ソフトウェアのインストール処理やマシンの制御処理など)、等の利用者との間のインターフェースを制御し、各種要求を受け付ける。   The UI control unit 221 (an example of a request receiving unit) controls the user interface of the portal server 20. The UI control unit 221 generates various display screens based on the information stored in the menu information storage unit 213 and the input information acquired from the user terminal device 10, and transmits various display screens to the user terminal via the network NW1. It is displayed on the display unit 12 of the device 10. Further, the UI control unit 221 executes various processes based on the input information acquired from the user terminal device 10 via the network NW1. For example, the UI control unit 221 performs user login processing, management processing of the tenant 60, creation of virtual machines, management processing of the management server 40 and test server 50 for each tenant 60 (for example, software installation processing and machine control) Control the interface with the user, such as processing), etc., and receive various requests.

例えば、UI制御部221は、図8〜図11に示すような表示画面を、利用者端末装置10の表示部12に表示させる。
図8〜図11は、本実施形態におけるポータルサーバ20により表示される表示画面の例を示す図である。
For example, the UI control unit 221 causes the display unit 12 of the user terminal device 10 to display a display screen as shown in FIGS.
8 to 11 are diagrams showing examples of display screens displayed by the portal server 20 in the present embodiment.

図8に示す表示画面G1は、試験サーバ50を管理するメニュー画面である。UI制御部221は、利用者端末装置10の入力部11を介して、例えば、試験サーバ50が選択された場合に、ネットワークNW1を介して、当該表示画面G1のデータを送信して、利用者端末装置10の表示部12に表示させる。表示画面G1において、UI制御部221は、仮想マシンの選択(選択ウインドウSW1参照)、“コンテナの追加”及び“ベアインストール”の選択(ボタンBT1を参照)などを受け付ける。   A display screen G1 shown in FIG. 8 is a menu screen for managing the test server 50. For example, when the test server 50 is selected via the input unit 11 of the user terminal device 10, the UI control unit 221 transmits the data of the display screen G1 via the network NW1 to the user. It is displayed on the display unit 12 of the terminal device 10. In the display screen G1, the UI control unit 221 receives selection of a virtual machine (see selection window SW1), selection of “add container” and “bear installation” (see button BT1), and the like.

また、図9に示す表示画面G2は、試験サーバ50にベアインストールを行うメニュー画面である。UI制御部221は、利用者端末装置10の入力部11を介して、例えば、“ベアインストール”が選択された場合に、ネットワークNW1を介して、当該表示画面G2のデータを送信して、利用者端末装置10の表示部12に表示させる。   Further, a display screen G2 shown in FIG. 9 is a menu screen for performing bare installation on the test server 50. The UI control unit 221 transmits the data of the display screen G2 via the network NW1 through the input unit 11 of the user terminal device 10, for example, when "bear installation" is selected. It is displayed on the display unit 12 of the person terminal device 10.

ここで、UI制御部221は、選択された試験サーバ50の「サーバタイプ」を仮想マシン情報記憶部214から取得し、取得した試験サーバ50の「サーバタイプ」に基づいて、当該試験サーバ50にインストール可能なツールをインストーラ情報記憶部215から抽出する。UI制御部221は、抽出したインストール可能なツールの情報を表示部12に表示させる。表示画面G2において、UI制御部221は、ベアインストールするツール名及びバージョンを受け付ける。   Here, the UI control unit 221 acquires the “server type” of the selected test server 50 from the virtual machine information storage unit 214, and the test server 50 receives the “server type” of the acquired test server 50. An installable tool is extracted from the installer information storage unit 215. The UI control unit 221 causes the display unit 12 to display the extracted installable tool information. In the display screen G2, the UI control unit 221 receives a tool name and a version for bare installation.

このように、UI制御部221は、利用者端末装置10の表示部12にメニュー画面(表示画面G2)を表示させて、テナント60に対応する利用者から、ソフトウェアの開発環境の要求情報(ツール名及びバージョン)を受け付ける。
また、UI制御部221は、利用者端末装置10の入力部11を介して、送信ボタンBT2が押下された場合に、後述する命令実行部222に、選択したツール名及びバージョンに対応するソフトウェアをベアインストールするインストール依頼を生成及び出力させる。
As described above, the UI control unit 221 causes the display unit 12 of the user terminal device 10 to display the menu screen (display screen G2), and the user corresponding to the tenant 60 requests information on the software development environment (tool Name and version).
Further, when the transmission button BT2 is pressed via the input unit 11 of the user terminal device 10, the UI control unit 221 causes the command execution unit 222 described later to execute the software corresponding to the selected tool name and version. Generate and output an installation request for bare installation.

また、図10に示す表示画面G3は、試験サーバ50にコンテナの追加を行うメニュー画面である。UI制御部221は、利用者端末装置10の入力部11を介して、例えば、“コンテナの追加”が選択された場合に、ネットワークNW1を介して、当該表示画面G3のデータを送信して、利用者端末装置10の表示部12に表示させる。   Further, a display screen G3 shown in FIG. 10 is a menu screen for adding a container to the test server 50. For example, when “add container” is selected via the input unit 11 of the user terminal device 10, the UI control unit 221 transmits the data of the display screen G3 via the network NW1. The display unit 12 of the user terminal device 10 is displayed.

ここで、UI制御部221は、選択された試験サーバ50の「サーバタイプ」を仮想マシン情報記憶部214から取得し、取得した試験サーバ50の「サーバタイプ」に基づいて、当該試験サーバ50にインストール可能なコンテナをコンテナ情報記憶部216から抽出する。UI制御部221は、抽出したインストール可能なコンテナの情報を表示部12に表示させる。なお、UI制御部221は、コンテナに対応する起動ポートの情報を、コンテナ情報記憶部216の「ポート情報」から取得して、設定可能なプロトコルの種別を表示させる。   Here, the UI control unit 221 acquires the “server type” of the selected test server 50 from the virtual machine information storage unit 214, and the test server 50 receives the “server type” of the acquired test server 50. An installable container is extracted from the container information storage unit 216. The UI control unit 221 causes the display unit 12 to display the extracted installable container information. The UI control unit 221 acquires the information of the activation port corresponding to the container from the “port information” of the container information storage unit 216, and displays the type of settable protocol.

表示画面G3において、UI制御部221は、追加(インストール)するコンテナのツール名、バージョン、及び起動ポートの情報を受け付ける。ここで、起動ポートの情報は、コンテナのソフトウェアが外部と接続するための外部ポート情報である。また、ツール名は、ソフトウェアの識別情報の一例である。   In the display screen G3, the UI control unit 221 receives information on the tool name, version, and activation port of the container to be added (installed). Here, the start port information is external port information for the container software to connect with the outside. The tool name is an example of software identification information.

このように、UI制御部221は、ソフトウェアの開発環境の要求情報として、コンテナを利用してインストールするソフトウェアの識別情報と、当該ソフトウェアのバージョン情報と、当該ソフトウェアが外部と接続するための外部ポート情報とを受け付ける。
また、UI制御部221は、利用者端末装置10の入力部11を介して、送信ボタンBT2が押下された場合に、後述する命令実行部222に、選択したツール名及びバージョンに対応するソフトウェアを、起動ポートに対応する設定によりコンテナを利用してインストールするインストール依頼を生成及び出力させる。
As described above, the UI control unit 221 includes, as request information of the software development environment, identification information of software to be installed using the container, version information of the software, and an external port for connecting the software to the outside. Accept information and
Further, when the transmission button BT2 is pressed via the input unit 11 of the user terminal device 10, the UI control unit 221 causes the command execution unit 222 described later to execute the software corresponding to the selected tool name and version. Then, an installation request to install using a container is generated and output by setting corresponding to the activation port.

また、図11に示す表示画面G4は、試験サーバ50のコンテナの制御を行うメニュー画面である。表示画面G3において、UI制御部221は、利用者端末装置10の入力部11を介して、例えば、制御ボタンBT3の“停止”、“再起動”などの制御の指示を受け付ける。UI制御部221は、後述する命令実行部222に、コンテナ制御の指示に対応したコンテナ制御依頼を生成及び出力させる。   Further, a display screen G4 shown in FIG. 11 is a menu screen for controlling the container of the test server 50. On the display screen G3, the UI control unit 221 receives control instructions such as “stop” and “restart” of the control button BT3 via the input unit 11 of the user terminal device 10. The UI control unit 221 causes the command execution unit 222 described later to generate and output a container control request corresponding to the container control instruction.

また、UI制御部221は、利用者情報記憶部212が記憶する利用者情報に基づいて、利用者のログイン処理を実行する。
また、UI制御部221は、テナント情報記憶部211が記憶するテナント情報に基づいて、利用者に対応するテナント60の判定し、当該テナントに対応する仮想マシンを仮想マシン情報記憶部214から抽出する。UI制御部221は、抽出した仮想マシンを、テナントに対応する仮想マシンとして、利用者端末装置10の表示部12に表示させる。
Further, the UI control unit 221 executes a login process of the user based on the user information stored in the user information storage unit 212.
Further, the UI control unit 221 determines the tenant 60 corresponding to the user based on the tenant information stored by the tenant information storage unit 211, and extracts a virtual machine corresponding to the tenant from the virtual machine information storage unit 214. . The UI control unit 221 displays the extracted virtual machine on the display unit 12 of the user terminal device 10 as a virtual machine corresponding to the tenant.

命令実行部222(インストール依頼部)は、UI制御部221が受け付けた、利用者からの各種要求に応じて、各種命令(例えば、インストール依頼の出力、コンテナ制御依頼の出力など)を実行する。
命令実行部222は、例えば、UI制御部221によって受け付けた要求情報に基づいて、開発環境用のソフトウェア及び設定情報を決定し、当該開発環境用のソフトウェアを、テナント60に対応する試験サーバ50に設定情報の示す設定でインストールさせるインストール依頼を生成する。命令実行部222は、要求情報に基づいて、開発環境用のソフトウェアをインストールするための手順を規定したプレイブックを指定するプレイブック情報(手順指定情報)を含むインストール依頼を生成する。ここで、プレイブック情報には、上述したプレイブック情報記憶部217が記憶する「プレイブックID」、「ファイル名」、及び「格納場所」などが含まれる。
The instruction execution unit 222 (installation request unit) executes various instructions (for example, output of an installation request, output of a container control request, and the like) according to various requests from the user received by the UI control unit 221.
The instruction execution unit 222 determines, for example, software for development environment and setting information based on the request information accepted by the UI control unit 221, and the software for development environment is transmitted to the test server 50 corresponding to the tenant 60. Generate an installation request to install with the settings indicated by the setting information. Based on the request information, the instruction execution unit 222 generates an installation request including playbook information (procedure designation information) specifying a playbook defining a procedure for installing software for a development environment. Here, the playbook information includes “playbook ID”, “file name”, “storage location”, and the like stored in the above-described playbook information storage unit 217.

なお、インストール依頼には、プレイブック情報の他に、開発環境用のソフトウェアをインストールする試験サーバ50を指定する情報(例えば、「マシンID」、「IPアドレス」など)が含まれている。管理サーバ40は、インストール依頼に含まれる試験サーバ50を指定する情報に基づいて、対象の試験サーバ50を判定(決定)する。   In addition to the playbook information, the installation request includes information (for example, “machine ID”, “IP address”, etc.) for specifying the test server 50 on which the software for the development environment is to be installed. The management server 40 determines (determines) the target test server 50 based on the information specifying the test server 50 included in the installation request.

例えば、ベアインストールを行う場合に、命令実行部222は、例えば、UI制御部221によって受け付けたツール名及びバージョンに対応する「ツールID」に基づいて、インストーラ情報記憶部215から、「プレイブックID」を取得する。命令実行部222は、取得した「プレイブックID」に対応するプレイブック情報をプレイブック情報記憶部217から取得し、当該プレイブック情報を含むインストール依頼を生成する。   For example, when bare installation is performed, the command execution unit 222 uses, for example, the “playbook ID” from the installer information storage unit 215 based on the “tool ID” corresponding to the tool name and version received by the UI control unit 221. To get The instruction execution unit 222 acquires playbook information corresponding to the acquired “playbook ID” from the playbook information storage unit 217, and generates an installation request including the playbook information.

また、例えば、コンテナを利用したインストールを行う場合に、命令実行部222は、例えば、UI制御部221によって受け付けたコンテナ名及びバージョンに対応する「コンテナID」に基づいて、コンテナ情報記憶部216から、「プレイブックID」を取得する。命令実行部222は、取得した「プレイブックID」に対応するプレイブック情報をプレイブック情報記憶部217から取得する。また、命令実行部222は、UI制御部221によって受け付けた起動ポートを外部ポート情報として、内部ポート情報(コンテナ情報記憶部216の「ポート情報」のポート番号)と対応付ける設定情報を生成する。命令実行部222は、当該プレイブック情報及び設定情報を含むインストール依頼を生成する。このように、命令実行部222は、要求情報に対応するソフトウェアを、当該ソフトウェアに予め設定された内部ポート情報と外部ポート情報とを対応付けて、コンテナを利用してインストールさせるインストール依頼を生成する。   Also, for example, when performing installation using a container, the instruction execution unit 222 may, for example, use the container information storage unit 216 based on the “container ID” corresponding to the container name and version received by the UI control unit 221. , "Playbook ID" to obtain. The instruction execution unit 222 acquires playbook information corresponding to the acquired “playbook ID” from the playbook information storage unit 217. Further, the instruction execution unit 222 generates setting information that associates the activation port accepted by the UI control unit 221 with the internal port information (port number of “port information” of the container information storage unit 216) as external port information. The instruction execution unit 222 generates an installation request including the playbook information and the setting information. As described above, the command execution unit 222 generates an installation request for installing the software corresponding to the request information using the container by associating the internal port information and the external port information preset in the software. .

命令実行部222は、上述のように生成したインストール依頼を、ネットワークNW1を介して、例えば、テナント60に対応する管理サーバ40に出力する。
また、例えば、コンテナの制御を行う場合に、命令実行部222は、UI制御部221によって受け付けた“停止”、“再起動”などの制御の指示に基づいて、コンテナ制御の指示に対応したコンテナ制御依頼を生成する。命令実行部222は、生成したコンテナ制御依頼を、ネットワークNW1を介して、例えば、テナント60に対応する管理サーバ40に出力する。
The instruction execution unit 222 outputs the installation request generated as described above, for example, to the management server 40 corresponding to the tenant 60 via the network NW1.
Also, for example, when controlling a container, the instruction execution unit 222 responds to the container control instruction based on the control instruction such as “stop” or “restart” received by the UI control unit 221. Generate a control request. The instruction execution unit 222 outputs the generated container control request to the management server 40 corresponding to the tenant 60, for example, via the network NW1.

再び、図1の説明に戻り、共通サーバ30は、例えば、コモンレジストリサーバ(Common registry Server)であり、例えば、ソフトウェアの開発環境を構築するためのソフトウェア及びプレイブックを記憶する。共通サーバ30は、例えば、ネットワークNW1を介して、インストールのためのプレイブック及びソフトウェア(インストーラ、コンテナイメージなど)を供給する。共通サーバ30は、共通記憶部31を備え、共通記憶部31は、プレイブック記憶部311と、インストーラ記憶部312と、コンテナ記憶部313とを備えている。
なお、情報処理システム1において、ポータルサーバ20及び共通サーバ30は、当該システムを提供するシステム運用者100によって提供及び管理される。
Referring back to FIG. 1 again, the common server 30 is, for example, a common registry server, and stores, for example, software and a playbook for constructing a software development environment. The common server 30 supplies playbooks and software (installer, container image, etc.) for installation via, for example, the network NW1. The common server 30 includes a common storage unit 31. The common storage unit 31 includes a playbook storage unit 311, an installer storage unit 312, and a container storage unit 313.
In the information processing system 1, the portal server 20 and the common server 30 are provided and managed by a system operator 100 who provides the system.

プレイブック記憶部311は、各種ソフトウェア及びコンテナに対応したプレイブック(プレイブックファイル)を記憶する。なお、プレイブック記憶部311は、複数のプレイブックを記憶しており、各プレイブックは、システム運用者100によって予め検証されたものである。例えば、プレイブックには、予め検証されたソフトウェアのバージョン及び組合せにより開発環境用のソフトウェアをインストールする手順が規定されている。   The playbook storage unit 311 stores playbooks (playbook files) corresponding to various software and containers. The playbook storage unit 311 stores a plurality of playbooks, and each playbook is verified in advance by the system operator 100. For example, in the playbook, a procedure is defined for installing software for a development environment by a pre-verified software version and combination.

インストーラ記憶部312は、各種ソフトウェアをインストールするためのインストーラを記憶する。なお、インストーラ記憶部312は、複数のインストーラを記憶しており、各インストーラは、システム運用者100によって予め検証されたものである。
コンテナ記憶部313は、各種コンテナをインストールするためのコンテナイメージを記憶する。なお、コンテナ記憶部313は、複数のコンテナイメージを記憶しており、各コンテナイメージは、システム運用者100によって予め検証されたものである。
The installer storage unit 312 stores an installer for installing various software. The installer storage unit 312 stores a plurality of installers, and each installer is verified in advance by the system operator 100.
The container storage unit 313 stores a container image for installing various containers. The container storage unit 313 stores a plurality of container images, and each container image is verified in advance by the system operator 100.

管理サーバ40は、テナント60ごとに構築され、例えば、テナント60内の試験サーバ50を管理するCI/CDサーバ(Continuous Integration/Continuous Deliveryサーバ)である。管理サーバ40は、ネットワークNW1を介して、ポータルサーバ20及び共通サーバ30と接続されるとともに、ネットワークNW2を介して、テナント60内の試験サーバ50と接続されている。
管理サーバ40は、例えば、ポータルサーバ20によって生成されたインストール依頼に応じて、試験サーバ50に、コンテナ型仮想化を利用して開発環境用のソフトウェアをインストールさせる。管理サーバ40は、インストール依頼に含まれるプレイブック情報(手順指定情報)に基づいて取得されたプレイブックに基づいて、開発環境用のソフトウェアを試験サーバ50にインストールさせる。
The management server 40 is constructed for each tenant 60 and is, for example, a CI / CD server (Continuous Integration / Continuous Delivery server) that manages the test server 50 in the tenant 60. The management server 40 is connected to the portal server 20 and the common server 30 via the network NW1, and is connected to the test server 50 in the tenant 60 via the network NW2.
For example, in response to an installation request generated by the portal server 20, the management server 40 causes the test server 50 to install software for a development environment using container-type virtualization. The management server 40 causes the test server 50 to install the software for the development environment based on the playbook acquired based on the playbook information (procedure designation information) included in the installation request.

また、管理サーバ40は、ポータルサーバ20が受け付けた制御指示に基づいて、試験サーバ50にインストールしているソフトウェアを制御する。例えば、管理サーバ40は、ポータルサーバ20によって生成されたコンテナ制御依頼に応じて、コンテナ制御を行う。
また、管理サーバ40は、管理制御部41を備えている。
The management server 40 also controls software installed in the test server 50 based on the control instruction received by the portal server 20. For example, the management server 40 performs container control in response to the container control request generated by the portal server 20.
In addition, the management server 40 includes a management control unit 41.

管理制御部41は、例えば、CPUなどを含むプロセッサであり、管理サーバ40を統括的に制御する。管理制御部41は、例えば、実行管理部411と、実行処理部412と、管理処理部413とを備えている。   The management control unit 41 is, for example, a processor including a CPU, and centrally controls the management server 40. The management control unit 41 includes, for example, an execution management unit 411, an execution processing unit 412, and a management processing unit 413.

実行管理部411(手順取得部の一例)は、例えば、ジョブ管理などを行うツールである「Jenkins」により実現される機能部である。実行管理部411は、ポータルサーバ20から受信したインストール依頼に含まれるプレイブック情報に基づいて、該当するプレイブックを、共通サーバ30のプレイブック記憶部311から取得する。ここで、プレイブック情報には、「ファイル名」及び「格納場所」が含まれており、実行管理部411は、「ファイル名」及び「格納場所」により、該当プレイブックをプレイブック記憶部311から取得する。実行管理部411は、取得したプレイブックによるインストール処理を実行処理部412に実行させる。   The execution management unit 411 (an example of a procedure acquisition unit) is a functional unit realized by, for example, “Jenkins” which is a tool for performing job management and the like. The execution management unit 411 acquires the corresponding playbook from the playbook storage unit 311 of the common server 30 based on the playbook information included in the installation request received from the portal server 20. Here, the playbook information includes “file name” and “storage location”, and the execution management unit 411 uses the “file name” and “storage location” to play the corresponding playbook as the playbook storage unit 311. Get from The execution management unit 411 causes the execution processing unit 412 to execute the installation process using the acquired playbook.

また、実行管理部411は、コンテナを利用してソフトウェアをインストールする場合には、インストール依頼に含まれる設定情報の設定にて、取得したプレイブックによるインストール処理を実行処理部412に実行させる。
また、実行管理部411は、ポータルサーバ20から受信したコンテナ制御依頼に基づいて、コンテナの制御処理を管理処理部413に実行させる。
In addition, when installing software using a container, the execution management unit 411 causes the execution processing unit 412 to execute the installation process using the acquired playbook by setting the setting information included in the installation request.
Further, the execution management unit 411 causes the management processing unit 413 to execute container control processing based on the container control request received from the portal server 20.

実行処理部412(構築処理部の一例)は、例えば、ジョブ実行を行うツールである「Ansible」により実現される機能部である。実行処理部412は、プレイブックに基づいて、各種処理を実行する。実行処理部412は、実行管理部411によって取得したプレイブックに基づいて、例えば、テナント60に対応する試験サーバ50に、少なくとも開発環境用のソフトウェアをインストールさせる。   The execution processing unit 412 (an example of a construction processing unit) is a functional unit realized by, for example, "Ansible" which is a tool for executing a job. The execution processing unit 412 executes various processes based on the playbook. The execution processing unit 412 installs, for example, at least software for a development environment in the test server 50 corresponding to the tenant 60 based on the playbook acquired by the execution management unit 411.

なお、プレイブックには、予め検証されたソフトウェアのバージョン及び組合せにより開発環境用のソフトウェアをインストールする手順が規定されており、実行処理部412は、当該プレイブックに基づいて、バージョン及び組合せが検証済みの開発環境用のソフトウェアをインストールさせる。
また、コンテナを利用してソフトウェアをインストールする場合には、実行処理部412は、試験サーバ50に、設定情報の示す設定(例えば、ポートの設定)でインストールさせる。
The playbook defines a procedure for installing software for the development environment based on software versions and combinations verified in advance, and the execution processing unit 412 verifies the versions and combinations based on the playbook. Install software for existing development environment.
Further, when installing software using a container, the execution processing unit 412 causes the test server 50 to install the software according to the setting indicated by the setting information (for example, setting of a port).

管理処理部413は、例えば、コンテナの管理などの各種制御を実行する。管理処理部413は、例えば、コンテナを「Docker」(登録商標)などのコンテナ仮想化 ツールを利用して、コンテナの“停止”、“再起動”などの制御を実行する。   The management processing unit 413 executes, for example, various controls such as management of a container. For example, the management processing unit 413 executes control such as “stop” and “restart” of the container using a container virtualization tool such as “Docker” (registered trademark).

試験サーバ50は、仮想マシンにより構築され、テナント60の利用者によってソフトウェアを開発するためのテストサーバである。試験サーバ50は、利用者によって開発したソフトウェアにより各種システムが構築されるとともに、各種システムの検証にも利用される。試験サーバ50は、ソフトウェア及びシステムの開発環境用のソフトウェア(開発のツール)がインストールされる。
試験サーバ50へのツールのインストールには、上述したように、ベアインストールと、コンテナを利用したインストールとがあり、ここで、図12を参照して説明する。
The test server 50 is a test server that is constructed by a virtual machine and for developing software by the user of the tenant 60. The test server 50 is used to verify various systems as well as to construct various systems using software developed by the user. In the test server 50, software (development tool) for software and system development environment is installed.
The installation of tools on the test server 50 includes bare installation and installation using a container, as described above, and will be described here with reference to FIG.

図12は、本実施形態における試験サーバ50のツールのインストール例を示す図である。
図12(a)は、試験サーバ50にベアインストールによりツールをインストールした場合の一例を示している。ベアインストールは、通常のインストールに相当し、試験サーバ50のOS(オペレーティングシステム)上に直接ツールをインストールする。
FIG. 12 is a diagram illustrating an installation example of tools of the test server 50 in the present embodiment.
FIG. 12A shows an example when a tool is installed in the test server 50 by bare installation. Bare installation corresponds to normal installation, and the tool is directly installed on the OS (operating system) of the test server 50.

また、図12(b)は、試験サーバ50にコンテナを利用してツールをインストールした場合の一例を示している。この場合には、試験サーバ50のOS上に、上述した「Docker」(登録商標)などのコンテナ管理ソフトをインストールした上で、仮想領域(コンテナ)を構築して、ツールをインストールする。図12(b)に示す例では、試験サーバ50には、“コンテナA”として“ツールA”がインストールされ、“コンテナB”として“ツールB”がインストールされている。   FIG. 12B shows an example when a tool is installed in the test server 50 using a container. In this case, after installing container management software such as “Docker” (registered trademark) described above on the OS of the test server 50, a virtual area (container) is constructed and a tool is installed. In the example shown in FIG. 12B, the "tool A" is installed as the "container A" and the "tool B" is installed as the "container B" in the test server 50.

なお、コンテナを利用した場合のインストールでは、同一のツールを異なるコンテナとして複数インストールすることも可能である。例えば、図12(b)に示す例では、試験サーバ50には、“コンテナA”及び“コンテナC”として、“ツールA”が2つインストールされている。この場合、1台の試験サーバ50において、同一のツールを利用して、異なる開発環境による検証などの作業を行うことが可能である。   In the case of using a container, a plurality of the same tools can be installed as different containers. For example, in the example shown in FIG. 12B, two “tools A” are installed in the test server 50 as “container A” and “container C”. In this case, in one test server 50, it is possible to perform an operation such as verification in a different development environment using the same tool.

次に、図面を参照して、本実施形態による情報処理システム1の動作について説明する。
まず、図13を参照して、本実施形態における試験サーバ50へのベアインストール処理について説明する。
Next, the operation of the information processing system 1 according to the present embodiment will be described with reference to the drawings.
First, with reference to FIG. 13, the bare installation process to the test server 50 in this embodiment is demonstrated.

図13は、本実施形態における試験サーバ50へのベアインストール処理の一例を示す図である。この図において、利用者によるログイン処理が予め完了しているものとする。
図13に示すように、まず、利用者端末装置10が、試験サーバ画面(例えば、図8の表示画面G1)のベアインストールの指定を送信する(ステップS101)。利用者端末装置10の端末制御部13は、入力部11を介して、試験サーバ50の指定とともにベアインストールの選択を受け付けて、ポータルサーバ20に送信する。
FIG. 13 is a diagram illustrating an example of bare installation processing to the test server 50 in the present embodiment. In this figure, it is assumed that the login process by the user has been completed in advance.
As shown in FIG. 13, first, the user terminal device 10 transmits the specification of bare installation on the test server screen (for example, the display screen G1 of FIG. 8) (step S101). The terminal control unit 13 of the user terminal device 10 receives the selection of the bare installation together with the designation of the test server 50 via the input unit 11 and transmits it to the portal server 20.

次に、ポータルサーバ20は、ベアインストール画面を利用者端末装置10に送信する(ステップS102)。ポータルサーバ20のUI制御部は、指定された試験サーバ50のベアインストールの選択に対して、メニュー画面(例えば、図9の表示画面G2)のデータを、利用者端末装置10に送信する。   Next, the portal server 20 transmits a bare installation screen to the user terminal device 10 (step S102). The UI control unit of the portal server 20 transmits data of a menu screen (for example, the display screen G2 of FIG. 9) to the user terminal device 10 in response to the selection of the bare installation of the designated test server 50.

次に、利用者端末装置10は、ベアインストール画面を表示する(ステップS103)。すなわち、端末制御部13は、例えば、表示画面G2を表示部12に表示させる。   Next, the user terminal device 10 displays a bare installation screen (step S103). That is, the terminal control unit 13 causes the display unit 12 to display, for example, the display screen G2.

次に、利用者端末装置10は、ベアインストール要求をポータルサーバ20に送信する(ステップS104)。すなわち、端末制御部13は、表示画面G2において、利用者によって入力部11を介してインストールするツール名及びバージョンが指定され、送信ボタンBT2が押下された場合に、指定されたツール名及びバージョンのベアインストール要求を、ポータルサーバ20に送信する。   Next, the user terminal device 10 transmits a bare installation request to the portal server 20 (step S104). That is, when the terminal control unit 13 specifies the tool name and version to be installed by the user via the input unit 11 on the display screen G2 and the transmission button BT2 is pressed, the specified tool name and version are displayed. A bare installation request is sent to the portal server 20.

次に、ポータルサーバ20が、インストール依頼を生成する(ステップS105)。ポータルサーバ20のUI制御部221が受け付けたベアインストール要求に基づいて、命令実行部222が、指定されたツール名及びバージョンのツールをベアインストールするインストール依頼を生成する。なお、インストール依頼には、プレイブック情報が含まれる。また、ベアインストールのインストール依頼を生成する処理の詳細については、図14を参照して後述する。   Next, the portal server 20 generates an installation request (step S105). Based on the bare installation request received by the UI control unit 221 of the portal server 20, the instruction execution unit 222 generates an installation request for bare installation of the specified tool name and version of the tool. The install request includes playbook information. The details of the process of generating the bare installation installation request will be described later with reference to FIG.

次に、ポータルサーバ20は、生成したインストール依頼を、利用者に対応するテナント60の管理サーバ40に送信する(ステップS106)。   Next, the portal server 20 transmits the generated installation request to the management server 40 of the tenant 60 corresponding to the user (step S106).

次に、管理サーバ40は、プレイブック要求を共通サーバ30に送信し(ステップS107)、対応するプレイブックを共通サーバ30から取得する(ステップS108)。すなわち、管理サーバ40の実行管理部411は、ポータルサーバ20から受信したインストール依頼に含まれるプレイブック情報に基づいて、該当するプレイブックを、共通サーバ30のプレイブック記憶部311から取得する。   Next, the management server 40 transmits a playbook request to the common server 30 (step S107), and acquires a corresponding playbook from the common server 30 (step S108). That is, the execution management unit 411 of the management server 40 acquires the corresponding playbook from the playbook storage unit 311 of the common server 30 based on the playbook information included in the installation request received from the portal server 20.

次に、管理サーバ40は、プレイブックによる実行モジュールを、指定された試験サーバ50に送信する(ステップS109)。実行管理部411は、利用者から指定された試験サーバ50に対して、取得したプレイブックを実行処理部412に実行させる。実行処理部412は、プレイブックに従って、ベアインストールを実行するための実行モジュールを試験サーバ50に送信する。   Next, the management server 40 transmits the execution module based on the playbook to the designated test server 50 (step S109). The execution management unit 411 causes the execution processing unit 412 to execute the acquired playbook with respect to the test server 50 specified by the user. The execution processing unit 412 transmits an execution module for executing bare installation to the test server 50 in accordance with the playbook.

次に、試験サーバ50は、プレイブックに従ってベアインストール処理を実行する(ステップS110)。すなわち、試験サーバ50は、管理サーバ40から受信した実行モジュールを実行することで、ベアインストール処理を実行する。なお、試験サーバ50は、ベアインストール処理の際に、管理サーバ40経由又は直接、共通サーバ30のインストーラ記憶部312からインストール資材をダウンロードする。   Next, the test server 50 executes a bare installation process in accordance with the playbook (step S110). That is, the test server 50 executes the bare installation process by executing the execution module received from the management server 40. The test server 50 downloads installation material from the installer storage unit 312 of the common server 30 via the management server 40 or directly during bare installation processing.

次に、試験サーバ50は、インストールの完了通知を管理サーバ40に送信し(ステップS111)、管理サーバ40は、インストールの完了通知をポータルサーバ20に送信する。   Next, the test server 50 transmits an installation completion notification to the management server 40 (step S111), and the management server 40 transmits the installation completion notification to the portal server 20.

次に、ポータルサーバ20は、利用者端末装置10に完了通知を送信して(ステップS113)、利用者端末装置10の表示部12にインストールの完了を表示させる(ステップS114)。すなわち、UI制御部221は、利用者端末装置10にベアインストールの完了を表示する画面データを送信し、利用者端末装置10の表示部12に表示させる。   Next, the portal server 20 transmits a completion notification to the user terminal device 10 (step S113), and displays the completion of installation on the display unit 12 of the user terminal device 10 (step S114). That is, the UI control unit 221 transmits screen data for displaying the completion of bare installation to the user terminal device 10, and causes the display unit 12 of the user terminal device 10 to display the screen data.

次に、図14を参照して、上述した図13のステップS105及びステップS106の処理の詳細について説明する。
図14は、本実施形態におけるベアインストールのインストール依頼を生成する処理の一例を示すフローチャートである。
Next, with reference to FIG. 14, the details of the processing in step S105 and step S106 in FIG. 13 described above will be described.
FIG. 14 is a flowchart illustrating an example of processing for generating an installation request for bare installation in the present embodiment.

図14に示すように、まず、命令実行部222は、インストールするツールの情報を取得する(ステップS201)。命令実行部222は、UI制御部221によって受け付けたツール名及びバージョンに対応する「ツールID」を、例えば、UI制御部221から取得する。   As shown in FIG. 14, first, the instruction execution unit 222 acquires information about a tool to be installed (step S201). The instruction execution unit 222 acquires, for example, the “tool ID” corresponding to the tool name and the version accepted by the UI control unit 221 from the UI control unit 221.

次に、命令実行部222は、ツールの情報からプレイブック情報を取得する(ステップS202)。命令実行部222は、取得した「ツールID」に基づいて、インストーラ情報記憶部215から、「ツールID」に対応する「プレイブックID」を取得する(図5参照)。そして、命令実行部222は、取得した「プレイブックID」に対応するプレイブック情報をプレイブック情報記憶部217から取得する。ここで、プレイブック情報は、例えば、「ファイル名」及び「格納場所」である(図7参照)。   Next, the instruction execution unit 222 acquires playbook information from the information of the tool (step S202). The instruction execution unit 222 acquires the “playbook ID” corresponding to the “tool ID” from the installer information storage unit 215 based on the acquired “tool ID” (see FIG. 5). Then, the instruction execution unit 222 acquires playbook information corresponding to the acquired “playbook ID” from the playbook information storage unit 217. Here, the playbook information is, for example, “file name” and “storage location” (see FIG. 7).

次に、命令実行部222は、プレイブック情報を含むインストール依頼を生成する(ステップS203)。ここで、命令実行部222は、利用者によって指定された試験サーバ50に指定のツールをインストールするインストール依頼を生成する。   Next, the command execution unit 222 generates an installation request including the playbook information (step S203). Here, the instruction execution unit 222 generates an installation request for installing the specified tool in the test server 50 specified by the user.

次に、命令実行部222は、インストール依頼を管理サーバ40に送信する(ステップS204)。すなわち、命令実行部222は、利用者に対応するテナント60の管理サーバ40に、インストール依頼を送信する。ステップS204の処理後に、命令実行部222は、インストール依頼を生成する処理を終了する。   Next, the command execution unit 222 transmits an installation request to the management server 40 (step S204). That is, the command execution unit 222 transmits an installation request to the management server 40 of the tenant 60 corresponding to the user. After the process of step S204, the instruction execution unit 222 ends the process of generating an installation request.

次に、図15を参照して、本実施形態における試験サーバ50へのコンテナを利用したインストール処理について説明する。
図15は、本実施形態における試験サーバ50へのコンテナを利用したインストール処理の一例を示す図である。この図において、利用者によるログイン処理が予め完了しているものとする。
Next, with reference to FIG. 15, the installation process using the container to the test server 50 in the present embodiment will be described.
FIG. 15 is a diagram illustrating an example of an installation process using a container to the test server 50 in the present embodiment. In this figure, it is assumed that the login process by the user has been completed in advance.

図15に示すように、まず、利用者端末装置10が、試験サーバ画面(例えば、図8の表示画面G1)のコンテナの追加の指定を送信する(ステップS301)。利用者端末装置10の端末制御部13は、入力部11を介して、試験サーバ50の指定とともにコンテナの追加を受け付けて、ポータルサーバ20に送信する。   As shown in FIG. 15, first, the user terminal device 10 transmits a designation of addition of a container of a test server screen (for example, the display screen G1 of FIG. 8) (step S301). The terminal control unit 13 of the user terminal device 10 receives the specification of the test server 50 and the addition of the container via the input unit 11 and transmits the container addition to the portal server 20.

次に、ポータルサーバ20は、コンテナの追加画面を利用者端末装置10に送信する(ステップS302)。ポータルサーバ20のUI制御部は、指定された試験サーバ50のコンテナの追加の選択に対して、メニュー画面(例えば、図10の表示画面G3)のデータを、利用者端末装置10に送信する。   Next, the portal server 20 transmits a container addition screen to the user terminal device 10 (step S302). The UI control unit of the portal server 20 transmits the data of the menu screen (for example, the display screen G3 in FIG. 10) to the user terminal device 10 in response to the additional selection of the container of the designated test server 50.

次に、利用者端末装置10は、コンテナの追加画面を表示する(ステップS303)。すなわち、端末制御部13は、例えば、表示画面G3を表示部12に表示させる。   Next, the user terminal device 10 displays a container addition screen (step S303). That is, the terminal control unit 13 displays the display screen G3 on the display unit 12, for example.

次に、利用者端末装置10は、コンテナのインストール要求をポータルサーバ20に送信する(ステップS304)。すなわち、端末制御部13は、表示画面G3において、利用者によって入力部11を介してインストールするコンテナ名及びバージョンと、起動ポートとが指定され、送信ボタンBT2が押下された場合に、指定されたコンテナ名及びバージョンを指定された起動ポート(外部ポート)でコンテナを利用してインストールするコンテナのインストール要求を、ポータルサーバ20に送信する。   Next, the user terminal device 10 transmits a container installation request to the portal server 20 (step S304). That is, the terminal control unit 13 is specified when the container name and version to be installed by the user via the input unit 11 and the start port are specified by the user on the display screen G3 and the send button BT2 is pressed. An installation request for a container to be installed using the container with the start port (external port) specified with the container name and version is sent to the portal server 20.

次に、ポータルサーバ20が、インストール依頼を生成する(ステップS305)。ポータルサーバ20のUI制御部221が受け付けたコンテナのインストール要求に基づいて、命令実行部222が、指定されたツール名及びバージョンのツールを、指定された設定(外部ポート)でコンテナを利用してインストールするインストール依頼を生成する。なお、インストール依頼には、プレイブック情報及び設定情報(外部ポート情報)が含まれる。また、コンテナを利用したインストールのインストール依頼を生成する処理の詳細については、図16を参照して後述する。   Next, the portal server 20 generates an installation request (step S305). Based on the container installation request received by the UI control unit 221 of the portal server 20, the instruction execution unit 222 uses the container with the specified tool name and version tool with the specified setting (external port). Generate an installation request to install. The installation request includes playbook information and setting information (external port information). Details of processing for generating an installation request for installation using a container will be described later with reference to FIG.

次に、ポータルサーバ20は、生成したインストール依頼を、利用者に対応するテナント60の管理サーバ40に送信する(ステップS306)。   Next, the portal server 20 transmits the generated installation request to the management server 40 of the tenant 60 corresponding to the user (step S306).

次に、管理サーバ40は、プレイブック要求を共通サーバ30に送信し(ステップS307)、対応するプレイブックを共通サーバ30から取得する(ステップS308)。   Next, the management server 40 transmits a playbook request to the common server 30 (step S307), and acquires a corresponding playbook from the common server 30 (step S308).

次に、管理サーバ40は、プレイブックによる実行モジュールを、指定された試験サーバ50に送信する(ステップS309)。実行管理部411は、利用者から指定された試験サーバ50に対して、設定情報の設定(外部ポート)により取得したプレイブックを、実行処理部412に実行させる。実行処理部412は、プレイブックに従って、設定情報の設定によりコンテナを利用したインストールを実行するための実行モジュールを試験サーバ50に送信する。   Next, the management server 40 transmits the playbook execution module to the designated test server 50 (step S309). The execution management unit 411 causes the execution processing unit 412 to execute the playbook acquired by setting the setting information (external port) with respect to the test server 50 designated by the user. The execution processing unit 412 transmits, to the test server 50, an execution module for performing installation using a container according to the setting of setting information in accordance with the playbook.

次に、試験サーバ50は、プレイブックに従ってコンテナ作成処理を実行する(ステップS310)。すなわち、試験サーバ50は、管理サーバ40から受信した実行モジュールを実行することで、コンテナを利用したインストール処理を実行する。なお、試験サーバ50は、コンテナを利用したインストール処理の際に、管理サーバ40経由又は直接、共通サーバ30のコンテナ記憶部313からコンテナイメージをダウンロードする。   Next, the test server 50 executes container creation processing according to the playbook (step S310). That is, the test server 50 executes the execution module received from the management server 40 to execute the installation process using the container. The test server 50 downloads the container image from the container storage unit 313 of the common server 30 via the management server 40 or directly in the installation process using the container.

続く、ステップS311からステップS314までの処理は、上述した図13に示すステップS111からステップS114までの処理と同様であるため、ここではその説明を省略する。なお、ステップS313及びステップS314の処理において、UI制御部221は、利用者端末装置10にコンテナ追加の完了を表示する画面データを送信し、利用者端末装置10の表示部12に表示させる。   The subsequent processing from step S311 to step S314 is the same as the processing from step S111 to step S114 shown in FIG. 13 described above, and a description thereof will be omitted here. In the processes of steps S313 and S314, the UI control unit 221 transmits screen data for displaying the completion of container addition to the user terminal device 10, and causes the display unit 12 of the user terminal device 10 to display the screen data.

次に、図16を参照して、上述した図15のステップS305及びステップS306の処理の詳細について説明する。
図16は、本実施形態におけるコンテナを利用したインストール依頼を生成する処理の一例を示すフローチャートである。
Next, with reference to FIG. 16, the details of the process of step S305 and step S306 of FIG. 15 described above will be described.
FIG. 16 is a flowchart illustrating an example of processing for generating an installation request using a container according to the present embodiment.

図16に示すように、まず、命令実行部222は、インストールするコンテナの情報を取得する(ステップS401)。命令実行部222は、UI制御部221によって受け付けたコンテナ名及びバージョンに対応する「コンテナID」を、例えば、UI制御部221から取得する。   As shown in FIG. 16, first, the instruction execution unit 222 acquires information of the container to be installed (step S401). The instruction execution unit 222 acquires, for example, the “container ID” corresponding to the container name and the version accepted by the UI control unit 221 from the UI control unit 221.

次に、命令実行部222は、コンテナの情報からプレイブック情報を取得する(ステップS402)。命令実行部222は、取得した「コンテナID」に基づいて、コンテナ情報記憶部216から、「コンテナID」に対応する「プレイブックID」を取得する(図6参照)。そして、命令実行部222は、取得した「プレイブックID」に対応するプレイブック情報をプレイブック情報記憶部217から取得する。ここで、プレイブック情報は、例えば、「ファイル名」及び「格納場所」である(図7参照)。   Next, the instruction execution unit 222 acquires playbook information from the container information (step S402). The instruction execution unit 222 acquires a “playbook ID” corresponding to the “container ID” from the container information storage unit 216 based on the acquired “container ID” (see FIG. 6). Then, the instruction execution unit 222 acquires playbook information corresponding to the acquired “playbook ID” from the playbook information storage unit 217. Here, the playbook information is, for example, “file name” and “storage location” (see FIG. 7).

次に、命令実行部222は、プレイブック情報と設定情報とを含むインストール依頼を生成する(ステップS403)。ここで、命令実行部222は、利用者によって指定された試験サーバ50に指定のコンテナを、設定情報の設定(外部ポート)でインストールするインストール依頼を生成する。   Next, the command execution unit 222 generates an installation request including the playbook information and the setting information (step S403). Here, the command execution unit 222 generates an installation request for installing the designated container in the test server 50 designated by the user with the setting information setting (external port).

次に、命令実行部222は、インストール依頼を管理サーバ40に送信する(ステップS404)。すなわち、命令実行部222は、利用者に対応するテナント60の管理サーバ40に、インストール依頼を送信する。ステップS404の処理後に、命令実行部222は、インストール依頼を生成する処理を終了する。   Next, the command execution unit 222 transmits an installation request to the management server 40 (step S404). That is, the command execution unit 222 transmits an installation request to the management server 40 of the tenant 60 corresponding to the user. After the process of step S404, the instruction execution unit 222 ends the process of generating an installation request.

次に、図17を参照して、本実施形態におけるコンテナの制御処理について説明する。
図17は、本実施形態におけるコンテナの制御処理の一例を示す図である。この図において、利用者によるログイン処理が予め完了しているものとする。
Next, a container control process according to the present embodiment will be described with reference to FIG.
FIG. 17 is a diagram illustrating an example of container control processing in the present embodiment. In this figure, it is assumed that the login process by the user has been completed in advance.

図17に示すように、まず、利用者端末装置10が、試験サーバ画面(例えば、図8の表示画面G1)の試験サーバの指定を送信する(ステップS501)。利用者端末装置10の端末制御部13は、入力部11を介して、試験サーバ50の指定を受け付けて、ポータルサーバ20に送信する。   As shown in FIG. 17, first, the user terminal device 10 transmits the designation of the test server on the test server screen (for example, the display screen G1 in FIG. 8) (step S501). The terminal control unit 13 of the user terminal device 10 receives specification of the test server 50 via the input unit 11 and transmits the specification to the portal server 20.

次に、ポータルサーバ20は、コンテナ制御のメニュー画面を利用者端末装置10に送信する(ステップS502)。ポータルサーバ20のUI制御部は、指定された試験サーバ50の指定に対して、コンテナ制御のメニュー画面(例えば、図11の表示画面G4)のデータを、利用者端末装置10に送信する。   Next, the portal server 20 transmits a menu screen of container control to the user terminal device 10 (step S502). The UI control unit of the portal server 20 transmits the data of the container control menu screen (for example, the display screen G4 of FIG. 11) to the user terminal device 10 in response to the designation of the designated test server 50.

次に、利用者端末装置10は、コンテナ制御のメニュー画面を表示する(ステップS503)。すなわち、端末制御部13は、例えば、表示画面G4を表示部12に表示させる。   Next, the user terminal device 10 displays a menu screen for container control (step S503). That is, the terminal control unit 13 displays the display screen G4 on the display unit 12, for example.

次に、利用者端末装置10は、コンテナの制御要求をポータルサーバ20に送信する(ステップS504)。すなわち、端末制御部13は、表示画面G4において、利用者によって入力部11を介して、制御ボタンBT3の“停止”、“再起動”などのコンテナの制御が押下された場合に、指定されたコンテナの制御を行うコンテナの制御要求を、ポータルサーバ20に送信する。   Next, the user terminal device 10 transmits a container control request to the portal server 20 (step S504). In other words, the terminal control unit 13 is designated when the container control such as “stop” or “restart” of the control button BT3 is pressed by the user via the input unit 11 on the display screen G4. A container control request for controlling the container is transmitted to the portal server 20.

次に、ポータルサーバ20が、コンテナ制御依頼を生成する(ステップS505)。ポータルサーバ20のUI制御部221が受け付けたコンテナの制御要求に基づいて、命令実行部222が、コンテナ制御依頼を生成する。なお、コンテナ制御依頼には、コンテナIDなどのコンテナの指定情報が含まれる。   Next, the portal server 20 generates a container control request (step S505). Based on the container control request accepted by the UI control unit 221 of the portal server 20, the instruction execution unit 222 generates a container control request. The container control request includes container designation information such as a container ID.

次に、ポータルサーバ20は、生成したコンテナ制御依頼を、利用者に対応するテナント60の管理サーバ40に送信する(ステップS506)。
次に、管理サーバ40は、コンテナ制御の命令を、指定された試験サーバ50に送信する(ステップS507)。ここで、実行管理部411は、コンテナ制御依頼を受け付けて、管理処理部413に、コンテナ制御依頼に対応するコンテナ制御の命令を、試験サーバ50に送信させる。
Next, the portal server 20 transmits the generated container control request to the management server 40 of the tenant 60 corresponding to the user (step S506).
Next, the management server 40 transmits a container control command to the designated test server 50 (step S507). Here, the execution management unit 411 accepts the container control request, and causes the management processing unit 413 to transmit a container control instruction corresponding to the container control request to the test server 50.

次に、試験サーバ50は、コンテナ制御の命令により、コンテナ制御処理を実行する(ステップS508)。   Next, the test server 50 executes container control processing in accordance with a container control command (step S508).

続く、ステップS509からステップS512までの処理は、上述した図13に示すステップS111からステップS114までの処理と同様であるため、ここではその説明を省略する。なお、ステップS509及びステップS510の処理において、UI制御部221は、利用者端末装置10にコンテナ制御の完了を表示する画面データを送信し、利用者端末装置10の表示部12に表示させる。   The subsequent processing from step S509 to step S512 is the same as the processing from step S111 to step S114 shown in FIG. 13 described above, and a description thereof will be omitted here. In the processing of step S509 and step S510, the UI control unit 221 transmits screen data indicating completion of container control to the user terminal device 10 and causes the display unit 12 of the user terminal device 10 to display the screen data.

以上説明したように、本実施形態による情報処理システム1は、コンピュータリソースの提供を受ける契約を示す複数のテナント60それぞれに対応したソフトウェアの開発環境を構築可能な情報処理システム1であって、実行管理部411(手順取得部)と、実行処理部412(構築処理部)とを備える。実行管理部411は、テナント60に対応する利用者からの要求に応じたプレイブック(手順情報)を取得する。ここで、プレイブックは、例えば、共通のオペレーティングシステム上に仮想領域を構築するコンテナ型仮想化を利用してソフトウェアをインストールするための手順を規定した手順情報である。実行処理部412は、実行管理部411によって取得したプレイブックに基づいて、テナント60に対応する試験サーバ50に、少なくとも開発環境用のソフトウェアをインストールさせる。   As described above, the information processing system 1 according to the present embodiment is an information processing system 1 capable of constructing a software development environment corresponding to each of a plurality of tenants 60 indicating a contract for receiving provision of computer resources, A management unit 411 (procedure acquisition unit) and an execution processing unit 412 (construction processing unit) are provided. The execution management unit 411 acquires a playbook (procedure information) corresponding to the request from the user corresponding to the tenant 60. Here, the playbook is, for example, procedure information that defines a procedure for installing software using container-type virtualization that constructs a virtual area on a common operating system. The execution processing unit 412 installs at least the software for the development environment in the test server 50 corresponding to the tenant 60 based on the playbook acquired by the execution management unit 411.

これにより、本実施形態による情報処理システム1は、プレイブックに基づいて、コンテナを利用して、開発環境用のソフトウェアをインストールするため、例えば、ソフトウェアに関する専門知識を持っていない利用者、或いは、スキルレベルが低い利用者であっても、容易にソフトウェアの開発環境を構築することができる。よって、本実施形態による情報処理システム1は、ソフトウェアの開発環境を構築する際に、手順ミスを低減し、且つ、構築時間を短縮することができる。   Thereby, the information processing system 1 according to the present embodiment uses the container based on the playbook to install the software for the development environment, for example, a user who does not have specialized knowledge about the software, or Even users with low skill levels can easily build a software development environment. Therefore, when constructing the software development environment, the information processing system 1 according to the present embodiment can reduce a procedure error and shorten the construction time.

また、本実施形態による情報処理システム1は、ソフトウェアの開発環境を構築するためのソフトウェア及びプレイブックを記憶する共通サーバ30を備える。実行管理部411は、利用者からの要求に応じたプレイブックを共通サーバ30から取得し、実行処理部412は、プレイブックに基づいて、試験サーバ50に、共通サーバ30が記憶するソフトウェアをインストールさせる。   In addition, the information processing system 1 according to the present embodiment includes the common server 30 that stores software for constructing a software development environment and a playbook. The execution management unit 411 acquires a playbook corresponding to a request from the user from the common server 30, and the execution processing unit 412 installs the software stored in the common server 30 in the test server 50 based on the playbook. Let

これにより、本実施形態による情報処理システム1は、共通サーバ30により、ソフトウェアの開発環境を構築するためのソフトウェア及びプレイブックを一括管理することができる。よって、本実施形態による情報処理システム1は、利用者による手順ミスをさらに低減することができる。
また、ソフトウェア資産を共通サーバ30で一括管理するため、本実施形態による情報処理システム1では、ツールに関連するトラブルの対策や更新を容易に行うことができる。
Accordingly, the information processing system 1 according to the present embodiment can collectively manage software and playbooks for constructing a software development environment by the common server 30. Therefore, the information processing system 1 according to the present embodiment can further reduce a procedure error by the user.
In addition, since the software assets are collectively managed by the common server 30, the information processing system 1 according to the present embodiment can easily perform countermeasures and updates for troubles related to the tools.

また、本実施形態では、プレイブックには、予め検証されたソフトウェアのバージョン及び組合せにより開発環境用のソフトウェアをインストールする手順が規定されている。実行処理部412は、プレイブックに基づいて、バージョン及び組合せが検証済みの開発環境用のソフトウェアをインストールさせる。
これにより、本実施形態による情報処理システム1は、検証済みの開発環境用のソフトウェアを提供できるため、ツールに関連するトラブルを低減する、又は未然に防ぐことができる。
In this embodiment, the playbook defines a procedure for installing software for a development environment based on a previously verified version and combination of software. The execution processing unit 412 installs the software for the development environment whose version and combination have been verified based on the playbook.
Thus, the information processing system 1 according to the present embodiment can provide software for a verified development environment, and thus can reduce or prevent problems associated with tools.

また、本実施形態による情報処理システム1は、実行管理部411と、実行処理部412とを含み、テナント60ごとに構築された管理サーバ40を備える。
これにより、本実施形態による情報処理システム1は、インストール処理の負荷を分散することができる。また、例えば、管理サーバ40と試験サーバ50とをローカルなネットワーク(ネットワークNW2)に接続して、試験サーバ50を外部のネットワークから遮断することができるため、本実施形態による情報処理システム1は、開発環境のセキュリティを向上させることができる。
The information processing system 1 according to the present embodiment includes an execution management unit 411 and an execution processing unit 412, and includes a management server 40 constructed for each tenant 60.
Thereby, the information processing system 1 according to the present embodiment can distribute the load of the installation process. Further, for example, since the management server 40 and the test server 50 can be connected to a local network (network NW2) and the test server 50 can be disconnected from the external network, the information processing system 1 according to the present embodiment is It can improve the security of the development environment.

また、本実施形態による情報処理方法は、コンピュータリソースの提供を受ける契約を示す複数のテナント60それぞれに対応したソフトウェアの開発環境を構築可能な情報処理システムの情報処理方法であって、手順取得ステップと、構築処理ステップとを含む。手順取得ステップにおいて、実行管理部411が、共通のオペレーティングシステム上に仮想領域を構築するコンテナ型仮想化を利用してソフトウェアをインストールするための手順を規定したプレイブックであって、テナント60に対応する利用者からの要求に応じたプレイブックを取得する。構築処理ステップにおいて、実行処理部412が、手順取得ステップによって取得したプレイブックに基づいて、テナント60に対応する試験サーバ50に、少なくとも開発環境用のソフトウェアをインストールさせる。
これにより、本実施形態による情報処理方法は、上述した本実施形態による情報処理システム1と同様の効果を奏し、ソフトウェアの開発環境を構築する際に、手順ミスを低減し、且つ、構築時間を短縮することができる。
Further, the information processing method according to the present embodiment is an information processing method of an information processing system capable of constructing a software development environment corresponding to each of a plurality of tenants 60 indicating a contract for receiving provision of computer resources, And a construction processing step. In the procedure acquisition step, the execution management unit 411 is a playbook that defines a procedure for installing software using container-type virtualization that builds virtual areas on a common operating system, and corresponds to the tenant 60. The playbook according to the request from the user who performs is acquired. In the construction processing step, the execution processing unit 412 causes at least the software for the development environment to be installed in the test server 50 corresponding to the tenant 60 based on the playbook acquired in the procedure acquisition step.
As a result, the information processing method according to the present embodiment has the same effects as the information processing system 1 according to the present embodiment described above, and reduces a procedure error when building a software development environment. It can be shortened.

また、本実施形態による情報処理システム1は、UI制御部221(要求受付部)と、命令実行部222(インストール依頼部)と、実行処理部412とを備える。UI制御部221は、メニュー画面を表示させて、テナント60に対応する利用者から、ソフトウェアの開発環境の要求情報を受け付ける。命令実行部222は、UI制御部221によって受け付けた要求情報に基づいて、開発環境用のソフトウェア及び設定情報を決定し、当該開発環境用のソフトウェアを、テナント60に対応する試験サーバ50に設定情報の示す設定でインストールさせるインストール依頼を生成する。実行処理部412は、命令実行部222によって生成されたインストール依頼に応じて、試験サーバ50に、開発環境用のソフトウェアを設定情報の示す設定でインストールさせる。   The information processing system 1 according to the present embodiment includes a UI control unit 221 (request receiving unit), an instruction execution unit 222 (installation request unit), and an execution processing unit 412. The UI control unit 221 causes the menu screen to be displayed, and receives request information of the software development environment from the user corresponding to the tenant 60. The instruction execution unit 222 determines development environment software and setting information based on the request information received by the UI control unit 221, and sets the development environment software to the test server 50 corresponding to the tenant 60. Generate an installation request to install with the settings shown in. In response to the installation request generated by the instruction execution unit 222, the execution processing unit 412 causes the test server 50 to install the software for the development environment with the setting indicated by the setting information.

これにより、本実施形態による情報処理システム1は、UI制御部221によってメニュー画面で受け付けた要求情報に基づいて、開発環境用のソフトウェア及び設定情報を決定し、該開発環境用のソフトウェアを設定情報の示す設定で、試験サーバ50にインストールすることができる。そのため、本実施形態による情報処理システム1は、例えば、ソフトウェアに関する専門知識を持っていない利用者、或いは、スキルレベルが低い利用者であっても、容易にソフトウェアの開発環境を構築することができる。よって、本実施形態による情報処理システム1は、ソフトウェアの開発環境を構築する際に、手順ミスを低減し、且つ、構築時間を短縮することができる。   Thereby, the information processing system 1 according to the present embodiment determines software for development environment and setting information based on the request information accepted on the menu screen by the UI control unit 221, and sets the software for development environment Can be installed on the test server 50. Therefore, the information processing system 1 according to the present embodiment can easily construct a software development environment, for example, even a user who does not have specialized knowledge about software or a user with a low skill level. . Therefore, when constructing the software development environment, the information processing system 1 according to the present embodiment can reduce a procedure error and shorten the construction time.

例えば、本実施形態による情報処理システム1は、メニュー画面(例えば、図9の表示画面G2、図10の表示画面G3など)を選択することで、自動で開発環境用のソフトウェア及び設定情報を行うことができ、ソフトウェアの開発環境の構築時間を大幅に短縮することができる。   For example, the information processing system 1 according to the present embodiment automatically performs software for development environment and setting information by selecting a menu screen (for example, the display screen G2 of FIG. 9, the display screen G3 of FIG. 10, etc.). It is possible to greatly shorten the construction time of the software development environment.

また、本実施形態では、命令実行部222は、要求情報に基づいて、開発環境用のソフトウェアをインストールするための手順を規定したプレイブックを指定するプレイブック情報(手順指定情報)を含むインストール依頼を生成する。実行処理部412は、インストール依頼に含まれるプレイブック情報に基づいて取得されたプレイブックに基づいて、開発環境用のソフトウェアを試験サーバ50にインストールさせる。
これにより、本実施形態による情報処理システム1は、利用者の要求に応じたプレイブックを用いて、開発環境用のソフトウェアをインストールできるため、利用者による手順ミスをさらに低減することができる。
Further, in the present embodiment, the instruction execution unit 222 requests installation on the basis of the request information including playbook information (procedure designation information) for designating a playbook defining a procedure for installing software for a development environment. Is generated. The execution processing unit 412 causes the test server 50 to install the software for the development environment based on the playbook acquired based on the playbook information included in the installation request.
As a result, the information processing system 1 according to the present embodiment can install software for a development environment using a playbook according to the user's request, and therefore, it is possible to further reduce the procedure error by the user.

また、本実施形態による情報処理システム1は、複数のプレイブックを記憶する共通サーバ30から、プレイブック情報に対応するプレイブックを取得する実行管理部411(手順取得部)を備える。実行処理部412は、実行管理部411によって取得したプレイブックに基づいて、開発環境用のソフトウェアを試験サーバ50にインストールさせる。
これにより、本実施形態による情報処理システム1は、複数のプレイブックを記憶する共通サーバ30からプレイブックを取得するため、多様な開発環境の構築に対応することができる。また、共通サーバ30により、プレイブックを一括管理することができる。よって、本実施形態による情報処理システム1は、多様な開発環境の構築に対応させつつ、利用者による手順ミスをさらに低減することができる。
The information processing system 1 according to the present embodiment also includes an execution management unit 411 (procedure acquisition unit) that acquires a playbook corresponding to playbook information from the common server 30 that stores a plurality of playbooks. The execution processing unit 412 causes the test server 50 to install software for a development environment based on the playbook acquired by the execution management unit 411.
Thereby, since the information processing system 1 according to the present embodiment acquires a playbook from the common server 30 that stores a plurality of playbooks, it can cope with the construction of various development environments. Further, the playbooks can be collectively managed by the common server 30. Therefore, the information processing system 1 according to the present embodiment can further reduce the procedure error by the user while making it compatible with the construction of various development environments.

また、本実施形態では、UI制御部221は、ソフトウェアの開発環境の要求情報として、コンテナを利用してインストールするソフトウェアの識別情報(例えば、コンテナ名、コンテナIDなど)と、当該ソフトウェアのバージョン情報と、当該ソフトウェアが外部と接続するための外部ポート情報とを受け付ける。命令実行部222は、ソフトウェアの識別情報に対応するソフトウェアであって、バージョン情報の示すバージョンのソフトウェアを、当該ソフトウェアに予め設定された内部ポート情報と外部ポート情報とを対応付けて、コンテナを利用してインストールさせるインストール依頼を生成する。
これにより、本実施形態による情報処理システム1は、コンテナの外部ポートを指定したインストールを、専門知識を必要とせず容易に行うことができる。
Further, in the present embodiment, the UI control unit 221 uses the container as identification information of the software development environment (for example, container name, container ID, etc.) and version information of the software as the request information of the software development environment. And external port information for the software to connect to the outside. The instruction execution unit 222 is software corresponding to the software identification information, and uses the version of the software indicated by the version information by associating the internal port information and external port information preset in the software with a container. And generate an installation request to be installed.
Thereby, the information processing system 1 according to the present embodiment can easily perform installation in which the external port of the container is specified without requiring specialized knowledge.

また、本実施形態による情報処理システム1は、ポータルサーバ20を備える。ポータルサーバ20は、上述したUI制御部221と命令実行部222とを含み、複数のテナント60それぞれに対応したソフトウェアの開発環境を構築させる。
これにより、本実施形態による情報処理システム1は、ポータルサーバ20を用いることで、複数のテナント60に対応させることができるとともに、開発環境の要求情報に応じたソフトウェアのインストールを容易に行うことができる。よって、本実施形態による情報処理システム1は、開発環境の構築時間をさらに短縮することができる。
The information processing system 1 according to this embodiment includes a portal server 20. The portal server 20 includes the UI control unit 221 and the command execution unit 222 described above, and builds a software development environment corresponding to each of the plurality of tenants 60.
Thus, using the portal server 20, the information processing system 1 according to the present embodiment can cope with a plurality of tenants 60 and easily install software according to the required information of the development environment. it can. Therefore, the information processing system 1 according to the present embodiment can further shorten the development environment construction time.

また、本実施形態による情報処理方法は、要求受付ステップと、インストール依頼ステップと、構築処理ステップとを含む。要求受付ステップにおいて、UI制御部221が、メニュー画面を表示させて、テナント60に対応する利用者から、ソフトウェアの開発環境の要求情報を受け付ける。インストール依頼ステップにおいて、命令実行部222が、要求受付ステップによって受け付けた要求情報に基づいて、開発環境用のソフトウェア及び設定情報を決定し、当該開発環境用のソフトウェアを、テナント60に対応する試験サーバ50に設定情報の示す設定でインストールさせるインストール依頼を生成する。構築処理ステップにおいて、実行処理部412が、インストール依頼ステップによって生成されたインストール依頼に応じて、試験サーバ50に、開発環境用のソフトウェアを設定情報の示す設定でインストールさせる。
これにより、本実施形態による情報処理方法は、上述した本実施形態による情報処理システム1と同様の効果を奏し、ソフトウェアの開発環境を構築する際に、手順ミスを低減し、且つ、構築時間を短縮することができる。
The information processing method according to the present embodiment includes a request reception step, an installation request step, and a construction processing step. In the request receiving step, the UI control unit 221 causes the menu screen to be displayed, and receives the request information of the software development environment from the user corresponding to the tenant 60. In the installation request step, the command execution unit 222 determines the software and setting information for the development environment based on the request information received in the request reception step, and the software for the development environment is a test server corresponding to the tenant 60 50, an installation request to be installed with the setting indicated by the setting information is generated. In the construction processing step, the execution processing unit 412 causes the test server 50 to install the software for development environment with the setting indicated by the setting information in response to the installation request generated in the installation request step.
As a result, the information processing method according to the present embodiment has the same effects as the information processing system 1 according to the present embodiment described above, and reduces a procedure error when building a software development environment. It can be shortened.

また、本実施形態による情報処理システム1は、ポータルサーバ20と、管理サーバ40とを備えている。ポータルサーバ20は、テナント60に対応する利用者から、ソフトウェアの開発環境の要求情報を受け付け、受け付けた要求情報に基づいて、少なくとも開発環境用のソフトウェアを、テナント60に対応する試験サーバ50に、コンテナを利用してインストールさせるインストール依頼を生成する。管理サーバ40は、テナント60ごとに構築され、ポータルサーバ20によって生成されたインストール依頼に応じて、試験サーバ50に、コンテナ型仮想化を利用して開発環境用のソフトウェアをインストールさせる。   The information processing system 1 according to this embodiment includes a portal server 20 and a management server 40. The portal server 20 receives software development environment request information from a user corresponding to the tenant 60, and based on the received request information, at least the software for the development environment is transferred to the test server 50 corresponding to the tenant 60. Generate an installation request to install using a container. The management server 40 is constructed for each tenant 60 and causes the test server 50 to install development environment software using container-type virtualization in response to an installation request generated by the portal server 20.

これにより、本実施形態による情報処理システム1は、例えば、インストールに関わる計算リソースやジョブ管理を、テナント60ごとに構築された管理サーバ40に処理させることができる。よって、本実施形態による情報処理システム1は、管理サーバ40によって、処理を分散することができるため、複数のソフトウェアの開発環境を構築する際に、パフォーマンスが低下することを抑制することができる。   Thereby, the information processing system 1 according to the present embodiment can cause the management server 40 constructed for each tenant 60 to process, for example, calculation resources and job management related to installation. Therefore, since the information processing system 1 according to the present embodiment can distribute processing by the management server 40, it is possible to suppress a decrease in performance when a plurality of software development environments are constructed.

また、本実施形態では、ポータルサーバ20は、要求情報に基づいて、開発環境用のソフトウェアをインストールするための手順を規定したプレイブックを指定するプレイブック情報(手順指定情報)を含むインストール依頼を生成する。管理サーバ40は、インストール依頼に含まれるプレイブック情報に基づいて取得されたプレイブックに基づいて、開発環境用のソフトウェアを試験サーバ50にインストールさせる。
これにより、本実施形態による情報処理システム1は、利用者の要求に応じたプレイブックを用いて、開発環境用のソフトウェアをインストールできるため、利用者による手順ミスを低減することができる。
Further, in the present embodiment, the portal server 20 requests the installation request including the playbook information (procedure designation information) for designating the playbook defining the procedure for installing the software for the development environment based on the request information. Generate. The management server 40 causes the test server 50 to install the software for the development environment based on the playbook acquired based on the playbook information included in the installation request.
As a result, the information processing system 1 according to the present embodiment can install software for a development environment using a playbook in accordance with the user's request, and therefore can reduce procedure errors by the user.

また、本実施形態では、ポータルサーバ20と共通サーバ30とは、複数のテナント60に対して共通に構築されている。
これにより、本実施形態による情報処理システム1は、共通のポータルサーバ20及び共通サーバ30によって、各テナント60に対する開発環境の構築、及びプレイブックを一括管理することができる。
Further, in the present embodiment, the portal server 20 and the common server 30 are commonly configured for a plurality of tenants 60.
Thereby, the information processing system 1 according to the present embodiment can collectively manage the construction of the development environment for each tenant 60 and the playbook by the common portal server 20 and the common server 30.

また、本実施形態では、ポータルサーバ20は、試験サーバ50にインストールしているソフトウェアを制御する制御指示を、利用者から受け付ける。管理サーバ40は、ポータルサーバ20が受け付けた制御指示に基づいて、試験サーバ50にインストールしているソフトウェアを制御する。
これにより、本実施形態による情報処理システム1は、複数のソフトウェアを制御(管理)する際に、パフォーマンスが低下することを抑制することができる。
Further, in the present embodiment, the portal server 20 receives from the user a control instruction for controlling software installed in the test server 50. The management server 40 controls the software installed in the test server 50 based on the control instruction received by the portal server 20.
Thereby, when controlling (managing) a plurality of software, the information processing system 1 according to the present embodiment can suppress performance degradation.

また、本実施形態による情報処理方法は、第1のステップと、第2のステップとを含む。第1のステップにおいて、ポータルサーバ20が、テナント60に対応する利用者から、ソフトウェアの開発環境の要求情報を受け付け、受け付けた要求情報に基づいて、少なくとも開発環境用のソフトウェアを、テナント60に対応する試験サーバ50に、コンテナを利用してインストールさせるインストール依頼を生成する。第2のステップにおいて、テナント60ごとに構築された管理サーバ40が、第1のステップによって生成されたインストール依頼に応じて、試験サーバ50に、コンテナを利用して開発環境用のソフトウェアをインストールさせる。
これにより、本実施形態による情報処理方法は、上述した本実施形態による情報処理システム1と同様の効果を奏し、複数のソフトウェアの開発環境を構築する際に、パフォーマンスが低下することを抑制することができる。
The information processing method according to the present embodiment includes a first step and a second step. In the first step, the portal server 20 receives the request information of the software development environment from the user corresponding to the tenant 60, and supports at least the software for the development environment on the tenant 60 based on the received request information. An install request for causing the test server 50 to install using a container is generated. In the second step, the management server 40 built for each tenant 60 causes the test server 50 to install the software for the development environment using the container in response to the installation request generated in the first step. .
As a result, the information processing method according to the present embodiment has the same effect as the information processing system 1 according to the present embodiment described above, and suppresses a decrease in performance when a development environment for a plurality of software is constructed. Can do.

[第2の実施形態]
次に、図18を参照して、第2の実施形態による情報処理システム1aについて説明する。本実施形態による情報処理システム1aは、上述した第1の実施形態の情報処理システム1における管理サーバ40の機能をポータルサーバ20に含めた場合の変形例について説明する。
Second Embodiment
Next, an information processing system 1a according to the second embodiment will be described with reference to FIG. The information processing system 1a according to the present embodiment will be described with respect to a modification example in which the portal server 20 includes the function of the management server 40 in the information processing system 1 according to the first embodiment described above.

図18は、本実施形態による情報処理システム1aの一例を示すブロック図である。
図18に示すように、情報処理システム1aは、利用者端末装置10と、ポータルサーバ20aと、共通サーバ30と、複数のテナント60aのそれぞれが有する試験サーバ50を備えている。本実施形態において、情報処理システム1aは、複数のテナント60aそれぞれに対応したソフトウェアの開発環境を構築可能なシステムである。
この図において、図1に示す構成と同一の構成には、同一の符号を付与して、ここではその説明を省略する。
FIG. 18 is a block diagram illustrating an example of the information processing system 1a according to the present embodiment.
As shown in FIG. 18, the information processing system 1a includes a user terminal device 10, a portal server 20a, a common server 30, and a test server 50 included in each of a plurality of tenants 60a. In the present embodiment, the information processing system 1a is a system capable of constructing a software development environment corresponding to each of the plurality of tenants 60a.
In this figure, the same components as those shown in FIG. 1 are denoted by the same reference numerals, and the description thereof is omitted here.

なお、テナント60aは、コンピュータリソースの提供を受ける契約を示し、テナント60a−1、テナント60a−2、・・・は、それぞれ異なる契約を示している。また、本実施形態において、テナント60a−1、テナント60a−2、・・・は、情報処理システム1aが備える任意のテナントを示す場合、又は特に区別しない場合には、テナント60aとして説明する。
また、情報処理システム1aにおいて、ポータルサーバ20a及び共通サーバ30は、当該システムを提供するシステム運用者100によって提供及び管理される。
The tenant 60a indicates a contract for receiving provision of computer resources, and the tenant 60a-1, the tenant 60a-2, ... indicate different contracts. Furthermore, in the present embodiment, the tenant 60a-1, the tenant 60a-2, and so on will be described as the tenant 60a when indicating an arbitrary tenant included in the information processing system 1a or when not making a distinction in particular.
Further, in the information processing system 1a, the portal server 20a and the common server 30 are provided and managed by a system operator 100 who provides the system.

ポータルサーバ20aは、情報処理システム1aを利用するためのポータルサイトであり、各種メニュー画面及び操作画面などの表示データを、ネットワークNW1を介して、利用者端末装置10に送信して、各種メニュー画面及び操作画面を利用者端末装置10の表示部12に表示させる。また、ポータルサーバ20aは、利用者端末装置10からネットワークNW1を介して受信した入力情報に基づいて、各種処理を実行する。
また、ポータルサーバ20aは、ポータル記憶部21と、ポータル制御部22aとを備えている。
The portal server 20a is a portal site for using the information processing system 1a, transmits display data such as various menu screens and operation screens to the user terminal device 10 via the network NW1, and performs various menu screens. The operation screen is displayed on the display unit 12 of the user terminal device 10. The portal server 20a also executes various processes based on input information received from the user terminal device 10 via the network NW1.
The portal server 20a includes a portal storage unit 21 and a portal control unit 22a.

ポータル制御部22aは、例えば、CPUなどを含むプロセッサであり、ポータルサーバ20aを統括的に制御する。ポータル制御部22aは、例えば、UI制御部221と、命令実行部222と、実行管理部411と、実行処理部412と、管理処理部413とを備えている。実行管理部411、実行処理部412、及び管理処理部413の機能は、第1の実施形態の管理サーバ40が備える実行管理部411、実行処理部412、及び管理処理部413と同様であるので、ここではその説明を省略する。   The portal control unit 22a is, for example, a processor including a CPU and the like, and controls the portal server 20a in an integrated manner. The portal control unit 22 a includes, for example, a UI control unit 221, an instruction execution unit 222, an execution management unit 411, an execution processing unit 412, and a management processing unit 413. The functions of the execution management unit 411, the execution processing unit 412, and the management processing unit 413 are the same as those of the execution management unit 411, the execution processing unit 412, and the management processing unit 413 included in the management server 40 of the first embodiment. The description is omitted here.

以上説明したように、本実施形態による情報処理システム1aでは、第1の実施形態における管理サーバ40の機能をポータルサーバ20aが備える。このような構成においても、本実施形態による情報処理システム1aは、第1の実施形態による情報処理システム1と同様の効果を奏し、ソフトウェアの開発環境を構築する際に、手順ミスを低減し、且つ、構築時間を短縮することができる。   As described above, in the information processing system 1a according to the present embodiment, the portal server 20a includes the function of the management server 40 in the first embodiment. Even in such a configuration, the information processing system 1a according to the present embodiment exhibits the same effect as the information processing system 1 according to the first embodiment, and reduces procedure errors when constructing a software development environment, And construction time can be shortened.

なお、本発明は、上記の各実施形態に限定されるものではなく、本発明の趣旨を逸脱しない範囲で変更可能である。
例えば、上記の各実施形態において、情報処理システム1(1a)は、共通サーバ30を備える例を説明したが、共通サーバ30の共通記憶部31の一部、又は全部を、ポータルサーバ20(20a)又は管理サーバ40が備えるようにしてもよい。
In addition, this invention is not limited to said each embodiment, It can change in the range which does not deviate from the meaning of this invention.
For example, although the information processing system 1 (1a) described the example provided with the common server 30 in each of the above-described embodiments, a part or all of the common storage unit 31 of the common server 30 can be used as the portal server 20 (20a). ) Or the management server 40 may be provided.

また、上記の各実施形態において、情報処理システム1(1a)は、ポータルサーバ20(20a)のメニュー画面から、仮想マシンによりテナント60内の試験サーバ50及び管理サーバ40を、自動で構築できるようにしてもよい。この場合、OSのインストールやネットワークの構築などを、上述した開発環境の構築と同様の仕組み(プレイブックを取得してインストールする仕組み)を利用するようにしてもよい。これにより、情報処理システム1(1a)は、テナント60の仮想マシンの取得を含めた開発環境の構築を、手順ミスを低減し、且つ、構築時間を短縮して行うことができる。   In each of the above embodiments, the information processing system 1 (1a) can automatically construct the test server 50 and the management server 40 in the tenant 60 by the virtual machine from the menu screen of the portal server 20 (20a). It may be. In this case, OS installation, network construction, and the like may use the same mechanism as the development environment construction described above (a mechanism for acquiring and installing a playbook). As a result, the information processing system 1 (1a) can construct a development environment including acquisition of a virtual machine of the tenant 60 with reduced procedure errors and shortened construction time.

また、ネットワークの構築を行う場合に、ポータルサーバ20(20a)が、サーバの別に応じて、グローバルIPアドレス(Floating IPアドレス)、又はローカルIPアドレス(Non Floating IPアドレス)を適切に割振って、ネットワークを、自動で構築するようにしてもよい。これにより、標準的な開発環境のネットワークの構築を自動で行うことができるため、情報処理システム1(1a)は、利便性を向上させることができる。   Further, when constructing a network, the portal server 20 (20a) appropriately allocates a global IP address (Floating IP address) or a local IP address (Non Floating IP address) depending on the server, You may make it construct | assemble a network automatically. As a result, the network of the standard development environment can be automatically constructed, so that the information processing system 1 (1a) can improve the convenience.

また、上記の第1の実施形態において、情報処理システム1は、共通サーバ30とは別に、共通記憶部31と同様の記憶部を管理サーバ40に備え、定期的又は更新時に、共通記憶部31内の情報を、共通サーバ30から管理サーバ40に配信して同期させるようにしてもよい。この場合、実行管理部411及び実行処理部412は、共通サーバ30の代わりに、管理サーバ40内の記憶部から、プレイブックと、ソフトウェア(インストーラ及びコンテナイメージ)とを取得する。   In the first embodiment described above, the information processing system 1 includes a storage unit similar to the common storage unit 31 in the management server 40 separately from the common server 30, and periodically or at the time of updating, the common storage unit 31. The information may be synchronized from the common server 30 to the management server 40. In this case, the execution management unit 411 and the execution processing unit 412 acquire a playbook and software (installer and container image) from the storage unit in the management server 40 instead of the common server 30.

また、上記の第1の実施形態において、情報処理システム1は、試験サーバ50へのベアインストール及びコンテナを利用したインストールと同様の手法を用いて、管理サーバ40に対して、ベアインストール及びコンテナを利用したインストールを実行するようにしてもよい。   Further, in the first embodiment described above, the information processing system 1 performs bare installation and a container on the management server 40 using the same method as bare installation on the test server 50 and installation using the container. The installed installation may be executed.

なお、上述した情報処理システム1(1a)が備える各構成は、内部に、コンピュータシステムを有している。そして、上述した情報処理システム1(1a)が備える各構成の機能を実現するためのプログラムをコンピュータ読み取り可能な記録媒体に記録して、この記録媒体に記録されたプログラムをコンピュータシステムに読み込ませ、実行することにより上述した情報処理システム1(1a)が備える各構成における処理を行ってもよい。ここで、「記録媒体に記録されたプログラムをコンピュータシステムに読み込ませ、実行する」とは、コンピュータシステムにプログラムをインストールすることを含む。ここでいう「コンピュータシステム」とは、OSや周辺機器等のハードウェアを含むものとする。
また、「コンピュータシステム」は、インターネットやWAN、LAN、専用回線等の通信回線を含むネットワークを介して接続された複数のコンピュータ装置を含んでもよい。また、「コンピュータ読み取り可能な記録媒体」とは、フレキシブルディスク、光磁気ディスク、ROM、CD−ROM等の可搬媒体、コンピュータシステムに内蔵されるハードディスク等の記憶装置のことをいう。このように、プログラムを記憶した記録媒体は、CD−ROM等の非一過性の記録媒体であってもよい。
In addition, each structure with which the information processing system 1 (1a) mentioned above is provided has a computer system inside. Then, a program for realizing the functions of each component included in the information processing system 1 (1a) described above is recorded on a computer-readable recording medium, and the program recorded on the recording medium is read into the computer system, By executing, the processing in each configuration included in the information processing system 1 (1a) described above may be performed. Here, "to read and execute the program recorded on the recording medium into the computer system" includes installing the program on the computer system. The “computer system” mentioned here includes an OS and hardware such as peripheral devices.
Also, the “computer system” may include a plurality of computer devices connected via a network including communication lines such as the Internet, WAN, LAN, and dedicated lines. The “computer-readable recording medium” refers to a storage device such as a flexible medium, a magneto-optical disk, a portable medium such as a ROM and a CD-ROM, and a hard disk incorporated in a computer system. As described above, the recording medium storing the program may be a non-transitory recording medium such as a CD-ROM.

また、記録媒体には、当該プログラムを配信するために配信サーバからアクセス可能な内部又は外部に設けられた記録媒体も含まれる。なお、プログラムを複数に分割し、それぞれ異なるタイミングでダウンロードした後に情報処理システム1(1a)が備える各構成で合体される構成や、分割されたプログラムのそれぞれを配信する配信サーバが異なっていてもよい。さらに「コンピュータ読み取り可能な記録媒体」とは、ネットワークを介してプログラムが送信された場合のサーバやクライアントとなるコンピュータシステム内部の揮発性メモリ(RAM)のように、一定時間プログラムを保持しているものも含むものとする。また、上記プログラムは、上述した機能の一部を実現するためのものであってもよい。さらに、上述した機能をコンピュータシステムに既に記録されているプログラムとの組み合わせで実現できるもの、いわゆる差分ファイル(差分プログラム)であってもよい。   The recording medium also includes a recording medium provided internally or externally accessible from the distribution server for distributing the program. It should be noted that the program is divided into a plurality of parts, and the programs are downloaded at different timings, and then the configurations combined in each configuration of the information processing system 1 (1a) are combined, or the distribution servers for distributing each of the divided programs are different. Good. Furthermore, the “computer-readable recording medium” holds a program for a certain period of time, such as a volatile memory (RAM) inside a computer system that becomes a server or a client when the program is transmitted via a network. Including things. The program may be for realizing a part of the functions described above. Furthermore, it may be a so-called difference file (difference program) that can realize the above-described functions in combination with a program already recorded in the computer system.

また、上述した機能の一部又は全部を、LSI(Large Scale Integration)等の集積回路として実現してもよい。上述した各機能は個別にプロセッサ化してもよいし、一部、又は全部を集積してプロセッサ化してもよい。また、集積回路化の手法はLSIに限らず専用回路、又は汎用プロセッサで実現してもよい。また、半導体技術の進歩によりLSIに代替する集積回路化の技術が出現した場合、当該技術による集積回路を用いてもよい。   In addition, part or all of the above-described functions may be realized as an integrated circuit such as LSI (Large Scale Integration). Each function mentioned above may be processor-ized separately, and part or all may be integrated and processor-ized. Further, the method of circuit integration is not limited to LSI's, and implementation using dedicated circuitry or general purpose processors is also possible. In the case where an integrated circuit technology comes out to replace LSI's as a result of the advancement of semiconductor technology, integrated circuits based on such technology may also be used.

1、1a 情報処理システム
10 利用者端末装置
11 入力部
12 表示部
13 端末制御部
20、20a ポータルサーバ
21 ポータル記憶部
22、22a ポータル制御部
30 共通サーバ
31 共通記憶部
40、40−1、40−2 管理サーバ
41 管理制御部
50、51−1、51−2、52−1、52−2 試験サーバ
60、60a、60−1、60a−1、60−2、60a−2 テナント
100 システム運用者
211 テナント情報記憶部
212 利用者情報記憶部
213 メニュー情報記憶部
214 仮想マシン情報記憶部
215 インストーラ情報記憶部
216 コンテナ情報記憶部
217 プレイブック情報記憶部
221 UI制御部
222 命令実行部
311 プレイブック記憶部
312 インストーラ記憶部
313 コンテナ記憶部
411 実行管理部
412 実行処理部
413 管理処理部
1, 1a information processing system 10 user terminal device 11 input unit 12 display unit 13 terminal control unit 20, 20a portal server 21 portal storage unit 22, 22a portal control unit 30 common server 31 common storage unit 40, 40-1, 40 -2 Management server 41 Management control unit 50, 51-1, 51-2, 52-1, 52-2 Test server 60, 60a, 60-1, 60a-1, 60-2, 60a-2 Tenant 100 System operation Person 211 tenant information storage unit 212 user information storage unit 213 menu information storage unit 214 virtual machine information storage unit 215 installer information storage unit 216 container information storage unit 217 playbook information storage unit 221 UI control unit 222 command execution unit 311 playbook Storage unit 312 Installer storage unit 313 Container憶部 411 execution management unit 412 executes processing unit 413 managing processing unit

Claims (6)

コンピュータリソースの提供を受ける契約を示す複数のテナントそれぞれに対応したソフトウェアの開発環境を構築可能な情報処理システムであって、
共通のオペレーティングシステム上に仮想領域を構築するコンテナ型仮想化を利用してソフトウェアをインストールするための手順を規定した手順情報であって、前記テナントに対応する利用者からの要求に応じた手順情報を取得する手順取得部と、
前記手順取得部によって取得した前記手順情報に基づいて、前記テナントに対応する試験サーバに、少なくとも開発環境用のソフトウェアをインストールさせる構築処理部と
を備えることを特徴とする情報処理システム。
An information processing system capable of constructing a software development environment corresponding to each of a plurality of tenants indicating a contract for receiving provision of computer resources,
Procedure information that defines the procedure for installing software using container-type virtualization that builds a virtual area on a common operating system, and that corresponds to a request from a user corresponding to the tenant A procedure acquisition unit for acquiring
An information processing system comprising: a construction processing unit that installs at least software for a development environment on a test server corresponding to the tenant based on the procedure information acquired by the procedure acquisition unit.
前記ソフトウェアの開発環境を構築するためのソフトウェア及び前記手順情報を記憶する共通サーバを備え、
前記手順取得部は、前記利用者からの要求に応じた前記手順情報を前記共通サーバから取得し、
前記構築処理部は、前記手順情報に基づいて、前記試験サーバに、前記共通サーバが記憶する前記ソフトウェアをインストールさせる
ことを特徴とする請求項1に記載の情報処理システム。
Software for constructing the development environment of the software and a common server storing the procedure information;
The procedure acquisition unit acquires the procedure information according to a request from the user from the common server,
The information processing system according to claim 1, wherein the construction processing unit causes the test server to install the software stored in the common server based on the procedure information.
前記手順情報には、予め検証された前記ソフトウェアのバージョン及び組合せにより前記開発環境用のソフトウェアをインストールする手順が規定されており、
前記構築処理部は、前記手順情報に基づいて、前記バージョン及び前記組合せが検証済みの前記開発環境用のソフトウェアをインストールさせる
ことを特徴とする請求項1又は請求項2に記載の情報処理システム。
In the procedure information, a procedure for installing software for the development environment is defined according to the version and combination of the software verified in advance,
The information processing system according to claim 1, wherein the construction processing unit installs the software for the development environment whose version and the combination have been verified based on the procedure information.
前記手順取得部と、前記構築処理部とを含み、前記テナントごとに構築された管理サーバを備える
ことを特徴とする請求項1から請求項3のいずれか一項に記載の情報処理システム。
The information processing system according to any one of claims 1 to 3, further comprising a management server that includes the procedure acquisition unit and the construction processing unit and is constructed for each tenant.
コンピュータリソースの提供を受ける契約を示す複数のテナントそれぞれに対応したソフトウェアの開発環境を構築可能な情報処理システムの情報処理方法であって、
手順取得部が、共通のオペレーティングシステム上に仮想領域を構築するコンテナ型仮想化を利用してソフトウェアをインストールするための手順を規定した手順情報であって、前記テナントに対応する利用者からの要求に応じた手順情報を取得する手順取得ステップと、
構築処理部が、前記手順取得ステップによって取得した前記手順情報に基づいて、前記テナントに対応する試験サーバに、少なくとも開発環境用のソフトウェアをインストールさせる構築処理ステップと
を含むことを特徴とする情報処理方法。
An information processing method for an information processing system capable of constructing a software development environment corresponding to each of a plurality of tenants indicating a contract for receiving provision of computer resources,
Procedure information that specifies the procedure for installing software using container-type virtualization that constructs a virtual area on a common operating system, and a request from a user corresponding to the tenant A procedure acquisition step for acquiring procedure information according to
And a construction processing step in which a construction processing unit causes the test server corresponding to the tenant to install at least software for a development environment based on the procedure information obtained by the procedure obtaining step. Method.
コンピュータリソースの提供を受ける契約を示す複数のテナントそれぞれに対応したソフトウェアの開発環境を構築可能な情報処理システムが有するコンピュータに、
共通のオペレーティングシステム上に仮想領域を構築するコンテナ型仮想化を利用してソフトウェアをインストールするための手順を規定した手順情報であって、前記テナントに対応する利用者からの要求に応じた手順情報を取得する手順取得ステップと、
前記手順取得ステップによって取得した前記手順情報に基づいて、前記テナントに対応する試験サーバに、少なくとも開発環境用のソフトウェアをインストールさせる構築処理ステップと
を実行させるためのプログラム。
A computer included in an information processing system capable of constructing a software development environment corresponding to each of a plurality of tenants indicating a contract for receiving provision of computer resources,
Procedure information that defines the procedure for installing software using container-type virtualization that builds a virtual area on a common operating system, and that corresponds to a request from a user corresponding to the tenant Procedure acquisition step to acquire
A program for causing a test server corresponding to the tenant to execute at least a construction processing step of installing software for a development environment based on the procedure information acquired by the procedure acquisition step.
JP2018007716A 2018-01-19 2018-01-19 Information processing systems, information processing methods, and programs Active JP7067933B2 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
JP2018007716A JP7067933B2 (en) 2018-01-19 2018-01-19 Information processing systems, information processing methods, and programs

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
JP2018007716A JP7067933B2 (en) 2018-01-19 2018-01-19 Information processing systems, information processing methods, and programs

Publications (2)

Publication Number Publication Date
JP2019128617A true JP2019128617A (en) 2019-08-01
JP7067933B2 JP7067933B2 (en) 2022-05-16

Family

ID=67471407

Family Applications (1)

Application Number Title Priority Date Filing Date
JP2018007716A Active JP7067933B2 (en) 2018-01-19 2018-01-19 Information processing systems, information processing methods, and programs

Country Status (1)

Country Link
JP (1) JP7067933B2 (en)

Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2012069088A (en) * 2010-06-25 2012-04-05 Toshiba Corp Medical information processor and software distribution system
WO2016167086A1 (en) * 2015-04-17 2016-10-20 日本電信電話株式会社 Server selection device, server selection method, and server selection program
US20170132031A1 (en) * 2012-08-30 2017-05-11 Zte Corporation Method, system and device for managing virtual machine software in cloud environment

Patent Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2012069088A (en) * 2010-06-25 2012-04-05 Toshiba Corp Medical information processor and software distribution system
US20170132031A1 (en) * 2012-08-30 2017-05-11 Zte Corporation Method, system and device for managing virtual machine software in cloud environment
WO2016167086A1 (en) * 2015-04-17 2016-10-20 日本電信電話株式会社 Server selection device, server selection method, and server selection program

Non-Patent Citations (2)

* Cited by examiner, † Cited by third party
Title
"Oracle Container Cloud Service を使って Docker 環境を作ってみた", [ONLINE], JPN6021037063, 3 February 2017 (2017-02-03), ISSN: 0004600708 *
石田 愛, 渡邊 裕治: "クラウド上のコンテナサービスに対するパッケージ脆弱性自動評価システム", CSS2016 コンピュータセキュリティシンポジウム2016 論文集[CD−ROM], JPN6021007857, 4 October 2016 (2016-10-04), pages 237 - 242, ISSN: 0004600707 *

Also Published As

Publication number Publication date
JP7067933B2 (en) 2022-05-16

Similar Documents

Publication Publication Date Title
US20070113066A1 (en) Host build and rebuild system and method
KR100757896B1 (en) System and method for remote home-service download in home network system
EP2863281B1 (en) System and method to configure a field device
JP6880633B2 (en) Information processing equipment, information processing systems and programs
US10642547B2 (en) Information processing system and information processing method for generating an application providing screen for display at a requesting device
US11018931B2 (en) Data driven user interface for configuring device settings
JP7122270B2 (en) SYSTEM AND METHOD FOR SUPPORTING APPLICATION SOFTWARE DEVELOPMENT
JP6938887B2 (en) Information processing equipment, information processing systems and programs
US11252019B2 (en) Methods, apparatuses and systems for cloud-based disaster recovery
EP3995953A1 (en) System, method, and computer program product for improved embedded application data management
US11176002B2 (en) Methods, apparatuses and systems for cloud-based disaster recovery
TW201640376A (en) Cloud service system and method thereof
US20190114208A1 (en) Information processing apparatus
JP2005323093A (en) Remote operation control program utilizing web server
JP2021166020A (en) Information processing apparatus, installation management server, system, method for controlling those, and program
JP7067934B2 (en) Information processing systems, information processing methods, and programs
US11178221B2 (en) Methods, apparatuses and systems for cloud-based disaster recovery
JP7067935B2 (en) Information processing system and information processing method
JP7067933B2 (en) Information processing systems, information processing methods, and programs
WO2016080268A1 (en) Processing condition management system and production system
US20200192763A1 (en) Methods, apparatuses and systems for cloud-based disaster recovery
JP2019125104A (en) Authentication device, authentication method and authentication system
US10868935B2 (en) Information processing device, information processing method, non-transitory recording medium, and image forming system
JP2006244373A (en) Integrated security audit device, integrated security audit method, and integrated security audit program
KR20120057861A (en) New application creation system and method

Legal Events

Date Code Title Description
A80 Written request to apply exceptions to lack of novelty of invention

Free format text: JAPANESE INTERMEDIATE CODE: A80

Effective date: 20180216

A621 Written request for application examination

Free format text: JAPANESE INTERMEDIATE CODE: A621

Effective date: 20200318

A977 Report on retrieval

Free format text: JAPANESE INTERMEDIATE CODE: A971007

Effective date: 20210226

A131 Notification of reasons for refusal

Free format text: JAPANESE INTERMEDIATE CODE: A131

Effective date: 20210309

A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20210427

A131 Notification of reasons for refusal

Free format text: JAPANESE INTERMEDIATE CODE: A131

Effective date: 20210928

A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20211129

TRDD Decision of grant or rejection written
A01 Written decision to grant a patent or to grant a registration (utility model)

Free format text: JAPANESE INTERMEDIATE CODE: A01

Effective date: 20220419

A61 First payment of annual fees (during grant procedure)

Free format text: JAPANESE INTERMEDIATE CODE: A61

Effective date: 20220428

R150 Certificate of patent or registration of utility model

Ref document number: 7067933

Country of ref document: JP

Free format text: JAPANESE INTERMEDIATE CODE: R150