墨尔本大学COMP90015课业解析

题意:使用客户端-服务器体系结构,设计并实现允许并发的多线程服务器

客户端搜索单词的含义,添加新单词,并删除现有单词。

解析:使用socket构建一个可以连接多个客户端的多线程服务器,服务器从包含初始列表的文件中加载字典数据单词及其含义,数据在一个能够实现的结构中把存在内存中的高效单词搜索。添加或删除单词,数据结构将更新并反映变化。客户端它会创建绑定到服务器地址和端口的套接字数。此套接字在客户端-服务器交互期间保持打开状态。所有消息通过此套接字发送/接收

涉及技术点:socket,java Tcp/Udp套接字编程,GUI界面实现

实现代码:进行中。

更多可加微信哦

人美心善的小姐姐


COMP90015: Distributed Systems – Assignment 1

Multi-threaded Dictionary Server (15 marks)

Problem Description

Using a client-server architecture, design and implement a multi-threaded server that allows concurrent

clients to search the meaning(s) of a word, add a new word, and remove an existing word.

This assignment has been designed to demonstrate the use of two fundamental technologies that have

been discussed during the lectures:

 Sockets

 Threads

Hence, the assignment must make an EXPLICIT use of the two above. By explicit, we mean that in your

application, sockets and threads must be the lowest level of abstraction for network communication and

concurrency.

Architecture

 The system will follow a client-server architecture in which multiple clients can connect to a

(single) multi-threaded server and perform operations concurrently.

 The multi-threaded server may implement a thread-per-request, thread-per-connection, or

worker pool architecture. This is a design decision for you to make.

Interaction

 All communication will take place via sockets. These sockets can be either TCP or UDP, however,

keep in mind that all communication between clients and server is required to be reliable.

 You are responsible for designing your own message exchange protocol. Some data formats that

you may use include XML, JSON, Java Object Serialization, or you may choose to design your own.

Failure Model

 All communication between components has to be reliable. If you are using TCP, then the

reliability guarantees offered by the protocol are sufficient. If you decide to use UDP, then you

have to implement an infrastructure that offers reliable communication over UDP. For those of

you with previous experience using TCP, using UDP may be a rewarding challenge.

 It is expected that, on both the server and the client side, errors (by means of exception handling)

are properly managed. The errors include the following:

 Input from the console for what concerns the parameters passed as command line.

 Network communication (address not reachable, bad data...).

 I/O to and from disk (cannot find the dictionary file, error reading the file, etc...).

 Other errors you might come up with.

The application will be tested and validated against all these errors.

Functional Requirements

 Query the meaning(s) of a given word

The client should implement a function that is used to query the dictionary with the following

minimum (additional input/output parameters can be used as required) input and output:

Input: Word to search

Output: Meaning(s) of the word

Error: The client should clearly indicate if the word was not found or if an error occurred. In case

of an error, a suitable description of the error should be given to the user.

 Add a new word

Add a new word and one or more of its meanings to the dictionary. For the word to be added

successfully it should not exist already in the dictionary. Also, attempting to add a word without

an associated meaning should result in an error. A new word added by one client should be visible

to all other clients of the dictionary server. The minimum input and output parameters are as

follows:

Input: Word to add, meaning(s)

Output: Status of the operation (e.g., success, duplicate)

Error: The user should be informed if any errors occurred while performing the operation.

 Remove an existing word

Remove a word and all of its associated meanings from the dictionary. A word deleted by one

client should not be visible to any of the clients of the dictionary server. If the word does not exist

in the dictionary then no action should be taken. The minimum input and output parameters are

as follows:

Input: Word to remove

Output: Status of the operation (e.g., success, not found)

Error: The user should be informed if any errors occurred while performing the operation.

User Interface

A Graphical User Interface (GUI) is required for this project. You are free to design it and to use any

existing tools and libraries for this purpose.

Implementation Guidelines

These are guidelines only, you are allowed and encouraged to come up with your own design and

interfaces.

 When the server is launched, it loads the dictionary data from a file containing the initial list of

words and their meanings. These data is maintained in memory in a structure that enables an

efficient word search. When words are added or removed, the data structure is updated to

reflect the changes.

A sample command to start the server is:

> java –jar DictionaryServer.jar

Where <port> is the port number where the server will listen for incoming client connections

and

<dictionary-file> is the path to the file containing the initial dictionary data.

 When the client is launched, it creates a TCP socket bound to the server address and port

number. This socket remains open for the duration of the client-server interaction. All messages

are sent/received through this socket.

A sample command to start the client is:

> java –jar DictionaryClient.jar

Implementation Language

The assignment should be implemented in Java. Utilization of technologies such as RMI and JMS are not

allowed

.

Report

You should write a report describing your system and discussing your design choices. Your report should

include:

 The problem context in which the assignment has been given.

 A brief description of the components of the system.

 An overall class design and an interaction diagram.

 A critical analysis of the work done followed by the conclusions.

Please mind that the report is a

WRITTEN document, do not put only graphs. A report without any

descriptive text addressing the problem, architecture, protocols, and the analysis of the work done will

not be considered valid.

The length of the report is not fixed. A good report is auto-consistent and contains all the required

information for understanding and evaluating the work done. Given the level of complexity of the

assignment, a report in the range of 4 to 6 pages is reasonable. Please mind that the length of the report

is simply a guideline to help you in avoiding writing an extremely long or incomplete report.

It is important to put your details (name, surname, student id) in:

 The head page of the report.

 As a header in each of the files of the software project.

This will help to avoid any mistakes in locating the assignment and its components on both sides.

Submission

You need to submit the following via LMS:

 Your report in PDF format only.

 Two executable jar files (DictionaryClient.jar and DictionaryServer.jar) that will be used to run

your system on the day of the demo.

 Your source files in a .ZIP or .TAR archive only.

Submissions will be due on: Thursday 5 of September (5 pm).

Marking

The marking process will be structured by first evaluating whether the assignment (application + report)

is compliant with the specification given. This implies the following:

 Use of TCP/UDP sockets and threads for the application;

 proper use of concurrency in the server;

 proper handling of the errors;

 a report with the requested content and format (PDF);

 timeliness in submitting the assignment in the proper format (names, directory structure, etc.).

All of the above elements will earn you a maximum of 10 (out of 15) marks. The rest of the marks are

assigned to two elements:

 Excellence (3 marks - 2 for implementation, 1 for report). The assignment has not only been

implemented by meeting the minimum requirements but the design has been well thought and a

proper interaction with the user has been provided (notification of errors, which really help to

understand what went wrong). For what concerns the report excellence, the report is complete

and well written with the

proper graphs and a discussion and analysis of the system implemented

including advantages and disadvantages of your design choices. You need to explicitly write in

the Report all

Excellence elements (point-by-point listing with brief illustration/discussion

included) in a separate section.

 Creativity (2 marks). Any additional implementation such as a GUI for managing the server or

other enhancements to the code introducing advanced features (such as processing of user

requests within a server in scalable, reliable, and efficient manner) will be considered a plus.

For

example, using your own implementation of a thread pool (not Java’s) would earn you these

marks

. You need to explicitly write in the Report all Creativity elements (point-by-point listing

with brief illustration/discussion included) in a separate section.

NOTE 1 (EXTREMELY IMPORTANT): The excellence and the creativity marks (5 marks) cannot

compensate any lack in the first part (the one that scores up to 10 marks). Please concentrate

your efforts in getting the first 10 marks done and then proceed with the rest.

Note 2: Don’t document anything you haven’t implemented in the report. This is misconduct and will

result in severe penalties.

Demonstration Schedule and Venue

You are required to provide a demonstration of the working application and will have the opportunity to

discuss with the tutors the design and implementation choices made during the demo.

You are free to develop your system where you are more comfortable (at home, on one pc, on your laptop,

in the labs...) but keep in mind that the assignment is meant to be a distributed system that works on at

least two different machines in order to separate the client from the server.

We will announce the demo date, time, and venue closer to the due date. Each tutor will hold 2-3 demo

sessions and you will be required to showcase your system in one of the sessions held by the tutor of the

workshop in which you are enrolled.

If you need any clarification on the assignment, kindly ask questions during the tutorials or in the LMS

forum, so that all students benefit from it.

Note: You need to submit a printed copy of your report during the demonstration.

Penalties for late submissions of assignments

Assignments submitted late will be penalized in the following way:

 1 day late: -1 mark

 2 days late: -3 marks (-1 - 2)

 3 days late: -6 marks (-3 - 3)

 4 days late: -10 marks (-6 - 4)

 etc.

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,928评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,192评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,468评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,186评论 1 286
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,295评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,374评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,403评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,186评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,610评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,906评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,075评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,755评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,393评论 3 320
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,079评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,313评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,934评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,963评论 2 351

推荐阅读更多精彩内容