Professional Documents
Culture Documents
(12NG1A0502)
G.KALYANA LAKSHMI
(12NG1A0540)
P.OMKARAM
(13NG5A0506)
K.VENKATESH
(12NG1A0554)
2012-2016
DECLARATION
This is to certify that Project report entitled Designing high performance web
based computing services to promote tele medicine database management system
being submitted by
A.saisravani(12NG1A0502),G.kalyanalakshmi(12NG1A0540),
p.omkaram(13NG5A0506),K.venkatesh(12NG1A0554) in partial fulfilment of
requirement for the award of Bachelor of Technology degree in COMPUTER
SCIENCE & ENGINEERING from USHA RAMA COLLEGE OF
ENGINEERING AND TECHNOLOGY affiliated to Jawaharlal Nehru
Technological University, Kakinada.
This is a bonified record of work carried out by us and results
embodied in this project has not been reproduced or copied from any source. The
matter contain in this project report has not been submitted to any other Universities
or Institutes for the award of any Degree or Diploma.
A.SAI SRAVANI
(12NG1A0502)
G.KALYANA LAKSHMI
(12NG1A0540)
P.OMKARAM
(13NG5A0506)
K.VENKATESH
(12NG1A0554)
CERTIFICATE
This is to certify that Project report entitled Designing high performance
web based computing services to promote telemedicine database management
system being submitted by A.SAI SRAVANI (12NG1A0502),G.KALYANA
LAKSHMI (12NG1A0540), P.OMKARAM (13NG5A0506),K.VENKATESH
(12NG1A0540) in partial fulfilment of requirement for the award of Bachelor of
Technology degree in COMPUTER SCIENCE AND ENGINEERING from USHA
RAMA COLLEGE OF ENGINEERING AND TECHNOLOGY affiliated to
Jawaharlal Nehru Technological University, Kakinada
PROJECT GUIDE
B.RAJA SRINIVASAREDDY M.Tech, Ph.D
Assistant Professor
Associate Professor
EXTERNAL EXAMINER
ACKNOWLEDGEMENT
Ph.D.
M.Tech.
Head of the
Department of CSE, for his untiring guidance, constant encouragement and valuable
suggestions and for sparing time for me from his hectic schedule and without which I
could not have made this effort a success.
I would like to express my gratitude to K.MUNI MAHESH MS(UK). my project
supervisor for his encouragement and valuable suggestions
I would like to express my gratitude to B.RAJA SRINIVASAREDDY M TECH., Ph.D my
project supervisor for his encouragement and valuable suggestions.
I would like to thank all the members of teaching and non-teaching staff of
Computer Science and Engineering Department for all their support in completion of
this project.
Lastly I want to thank sincerely all of our Family Members & Friends for the
constant cooperation and moral support they had given till the completion of my
project.
A.SAI SRAVANI
G.KALYANA LAKSHMI
(12NG1A0502)
(12NG1A0540)
P.OMKARAM
K.VENKATESH
(13NG5A0506)
(12NG1A0554)
INTRODUCTION
What is Web Services?
A web service is a method of communication between two electronic
devices over the World Wide Web. A web service is a software function
provided at a network address over the web or the cloud, it is a service
that is "always on" as in the concept of utility computing.
The W3C defines a "Web service" as software system designed to
support interoperable machine-to-machine interaction over a network. It
has
an
interface
described
in
machine-processable
format
This
describes
the
service
in
terms
of
3.
The messages sent to, and received from, the web service are all in
the form of XML that complies to the schema, and which follows the
protocols described by the WSDL, using an XML protocol known as
SOAP (for Simple Object Access Protocol)
2.
4.
The client code will create an instance of the proxy class for the
service. It will call an instance method of the class, perhaps passing
some parameters. The proxy class will turn these parameters into
properly-formatted SOAP XML and will send them to the service.
5.
On the server side, the XML will likely be turned into parameters
again, and a server-side method will be called with those parameters.
6.
The server will do what it was requested to do, and may then return
a result. This result will be turned into SOAP XML, which will be sent
back to the client.
7.
The proxy class on the client will receive this XML, turn it back
into return values and will return that to the caller
The result is that the caller of a web service can treat the service
operations just like normal methods on normal objects. In most cases,
even the developer of the web service can treat the service like it is a
normal object with normal methods. But everything in the middle is
happening in SOAP XML, described by XML Schema, referenced by a
WSDL in XML.
Machine-to-machine interactions
Loose coupling
Interoperability
Platform-independence
Operating system-independence
Language-independence
LITERATURE SURVEY
1) A Cloud Computing Based 12-Lead ECG Telemedicine Service
SYSTEM REQUIREMENTS:
HARDWARE REQUIREMENTS:
System
Hard Disk
40 GB.
Floppy Drive
1.44 Mb.
Monitor
15 VGA Colour.
Mouse
Logitech.
Ram
512 Mb.
SOFTWARE REQUIREMENTS:
Operating system :
Windows XP/7.
Coding Language :
JAVA/J2EE
IDE
Netbeans 7.4
Database
MYSQL
SYSTEM STUDY
FEASIBILITY STUDY
ECONOMICAL FEASIBILITY
TECHNICAL FEASIBILITY
SOCIAL FEASIBILITY
ECONOMICAL FEASIBILITY
This study is carried out to check the economic impact that the
system will have on the organization. The amount of fund that the
company can pour into the research and development of the system is
limited. The expenditures must be justified. Thus the developed system as
well within the budget and this was achieved because most of the
technologies used are freely available. Only the customized products had
to be purchased.
TECHNICAL FEASIBILITY
SOCIAL FEASIBILITY
Software Environment
Java Technology
Simple
Architecture neutral
Object oriented
Portable
Distributed
High performance
Interpreted
Multithreaded
Robust
Dynamic
Secure
You can think of Java byte codes as the machine code instructions
for the Java Virtual Machine (Java VM). Every Java interpreter, whether
its a development tool or a Web browser that can run applets, is an
implementation of the Java VM. Java byte codes help make write once,
run anywhere possible. You can compile your program into byte codes
on any platform that has a Java compiler. The byte codes can then be run
on any implementation of the Java VM. That means that as long as a
computer has a Java VM, the same program written in the Java
programming language can run on Windows 2000, a Solaris workstation,
or on an iMac.
Native code is code that after you compile it, the compiled code
runs on a specific hardware platform. As a platform-independent
environment, the Java platform can be a bit slower than native code.
However, smart compilers, well-tuned interpreters, and just-in-time byte
code compilers can bring performance close to that of native code without
threatening portability.
What Can Java Technology Do?
The most common types of programs written in the Java
programming language are applets and applications. If youve
surfed the Web, youre probably already familiar with applets. An
applet is a program that adheres to certain conventions that allow it
to run within a Java-enabled browser.
However, the Java programming language is not just for writing
cute, entertaining applets for the Web. The general-purpose, high-
database. For example, the data source named Sales Figures might be a
SQL Server database, whereas the Accounts Payable data source could
refer to an Access database. The physical database referred to by a data
source can reside anywhere on the LAN.
The ODBC system files are not installed on your system by
Windows 95. Rather, they are installed when you setup a separate
database application, such as SQL Server Client or Visual Basic 4.0.
When the ODBC icon is installed in Control Panel, it uses a file called
ODBCINST.DLL. It is also possible to administer your ODBC data
sources through a stand-alone program called ODBCADM.EXE. There is
a 16-bit and a 32-bit version of this program and each maintains a
separate
list
of
ODBC
data
sources.
JDBC
In an effort to set an independent database standard API for Java;
Sun Microsystems developed Java Database Connectivity, or JDBC.
JDBC offers a generic SQL database access mechanism that provides a
consistent interface to a variety of RDBMSs. This consistent interface is
achieved through the use of plug-in database connectivity modules, or
drivers. If a database vendor wishes to have JDBC support, he or she
must provide the driver for each platform that the database and Java run
on.
To gain a wider acceptance of JDBC, Sun based JDBCs
framework on ODBC. As you discovered earlier in this chapter, ODBC
has widespread support on a variety of platforms. Basing JDBC on
ODBC will allow vendors to bring JDBC drivers to market much faster
than developing a completely new connectivity solution.
JDBC was announced in March of 1996. It was released for a 90
day public review that ended June 8, 1996. Because of user input, the
final JDBC v1.0 specification was released soon after.
The remainder of this section will cover enough information about JDBC
for you to know what it is about and how to use it effectively. This is by
no means a complete overview of JDBC. That would fill an entire book.
JDBC Goals
Few software packages are designed without goals in mind. JDBC
is one that, because of its many goals, drove the development of the API.
These goals, in conjunction with early reviewer feedback, have finalized
the JDBC class library into a solid framework for building database
applications in Java.
The goals that were set for JDBC are important. They will give you
some insight as to why certain classes and functionalities behave the way
they do. The eight design goals for JDBC are as follows:
Simple
Architecture-neutral
Object-oriented
Portable
Distributed
High-performance
Interpreted
multithreaded
Robust
Dynamic
Secure
Java Program
Compilers
Interpreter
My Program
IP datagrams
The IP layer provides a connectionless and unreliable delivery
system. It considers each datagram independently of the others.
Any association between datagram must be supplied by the
higher layers. The IP layer supplies a checksum that includes its
own header. The header includes the source and destination
addresses. The IP layer handles routing through an Internet. It is
also responsible for breaking up large datagram into smaller ones
for transmission and reassembling them at the other end.
UDP
UDP is also connectionless and unreliable. What it adds to IP
is a checksum for the contents of the datagram and port numbers.
These are used to give a client/server model - see later.
TCP
TCP supplies logic to give a reliable connection-oriented
protocol above IP. It provides a virtual circuit that two processes
can use to communicate.
Internet addresses
In order to use a service, you must be able to find it. The
Internet uses an address scheme for machines so that they can be
located. The address is a 32 bit integer which gives the IP
Total address
Port addresses
A service exists on a host, and is identified by its port. This is
a 16 bit number. To send a message to a server, you send it to the
port for that service of the host that it is running on. This is not
location transparency! Certain of these ports are "well known".
Sockets
A socket is a data structure maintained by the system to handle
network connections. A socket is created using the call socket. It
returns an integer that is like a file descriptor. In fact, under
Windows, this handle can be used with Read File and Write File
functions.
#include <sys/types.h>
#include <sys/socket.h>
int socket(int family, int type, int protocol);
Here "family" will be AF_INET for IP communications,
protocol will be zero, and type will depend on whether TCP or
UDP is used. Two processes wishing to communicate over a
network create a socket each. These are similar to two ends of a
pipe - but the actual pipe does not yet exist.
JFree Chart
JFreeChart is a free 100% Java chart library that makes it
easy for developers to display professional quality charts in their
applications. JFreeChart's extensive feature set includes:
for
many
output
types,
including
Swing
3. Dashboards
There is currently a lot of interest in dashboard displays. Create a
flexible dashboard mechanism that supports a subset of JFreeChart
chart types (dials, pies, thermometers, bars, and lines/time series) that
can be delivered easily via both Java Web Start and an applet.
4. Property Editors
The property editor mechanism in JFreeChart only handles a small
subset of the properties that can be set for charts. Extend (or
reimplement) this mechanism to provide greater end-user control
over the appearance of the charts.
4.Configurations overview
The configuration defines the basic run-time environment as a set of core
classes and a specific JVM that run on specific types of devices.
Currently, two configurations exist for J2ME, though others may be
defined in the future:
* Connected Limited Device Configuration (CLDC) is used
specifically with the KVM for 16-bit or 32-bit devices with limited
amounts of memory. This is the configuration (and the virtual machine)
used for developing small J2ME applications. Its size limitations make
CLDC more interesting and challenging (from a development point of
view) than CDC. CLDC is also the configuration that we will use for
developing our drawing tool application. An example of a small wireless
device running small applications is a Palm hand-held computer.
runs,
certain
profiles
are
associated
with
certain
configurations.
A skeleton profile upon which you can create your own profile, the
Foundation Profile, is available for CDC.
Profile 1: KJava
KJava is Sun's proprietary profile and contains the KJava API. The KJava
profile is built on top of the CLDC configuration. The KJava virtual
machine, KVM, accepts the same byte codes and class file format as the
classic J2SE virtual machine. KJava contains a Sun-specific API that runs
on the Palm OS. The KJava API has a great deal in common with the
J2SE Abstract Windowing Toolkit (AWT). However, because it is not a
standard J2ME package, its main package is com.sun.kjava. We'll learn
more about the KJava API later in this tutorial when we develop some
sample applications.
Profile 2: MIDP
MIDP is geared toward mobile devices such as cellular phones and
pagers. The MIDP, like KJava, is built upon CLDC and provides a
standard run-time environment that allows new applications and services
SYSTEM ANALYSIS
EXISTING SYSTEM:
Recently, many researchers have focused on designing web
medical database management systems that satisfy certain
performance levels. Such performance is evaluated by measuring
the amount of relevant and irrelevant data accessed and the amount
of transferred medical data during transactions processing time.
Several techniques have been proposed in order to improve
telemedicine database performance, optimize medical data
distribution, and control medical data proliferation. These
techniques believed that high performance for such systems can be
achieved by improving at least one of the database web
management services, namelydatabase fragmentation, data
distribution, websites clustering, distributed caching, and database
scalability.
DISADVANTAGES OF EXISTING SYSTEM:
Some of these data records may be overlapped or even redundant,
which increase the I/O transactions processing time and so the
system communications overhead.
These works have mostly investigated fragmentation, allocation
and sometimes clustering problems.
The transactions should be executed very fast in a flexible load
balancing database environment. When the number of sites in a
web database system increases to a large scale,
transactions
and
managing
huge
number
of
PROPOSED SYSTEM:
Our approach integrates three enhanced computing services
techniques
namely,
database
fragmentation,
network
sites
and
accessed
through
different
websites
and
data
fragmentation,
websites
clustering,
and
integrated
approach
significantly
improves
services
INPUT DESIGN
The input design is the link between the information system and the user.
It comprises the developing specification and procedures for data
preparation and those steps are necessary to put transaction data in to a
usable form for processing can be achieved by inspecting the computer to
read data from a written or printed document or it can occur by having
people keying the data directly into the system. The design of input
focuses on controlling the amount of input required, controlling the
errors, avoiding delay, avoiding extra steps and keeping the process
simple. The input is designed in such a way so that it provides security
and ease of use with retaining the privacy. Input Design considered the
following things:
What data should be given as input?
How the data should be arranged or coded?
The dialog to guide the operating personnel in providing input.
Methods for preparing input validations and steps to follow when
error occur.
OBJECTIVES
system.
OUTPUT DESIGN
A quality output is one, which meets the requirements of the end user and
presents the information clearly. In any system results of processing are
communicated to the users and to other system through outputs. In output
design it is determined how the information is to be displaced for
immediate need and also the hard copy output. It is the most important
and direct source information to the user. Efficient and intelligent output
design improves the systems relationship to help user decision-making.
1. Designing computer output should proceed in an organized, well
thought out manner; the right output must be developed while ensuring
that each output element is designed so that people will find the system
can use easily and effectively. When analysis design computer output,
they should Identify the specific output that is needed to meet the
requirements.
2.Select methods for presenting information.
3.Create document, report, or other formats that contain information
produced by the system.
The output form of an information system should accomplish one or more
of the following objectives.
Convey information about past activities, current status or
projections of the
Future.
Signal important events, opportunities, problems, or warnings.
Trigger an action.
Confirm an action.
IMPLEMENTATION
MODULES:
MODULES DESCSRIPTION:
Web Architecture and Communications System Model
In the first module, the telemedicine approach is designed to support web
database provider with computing services that can be implemented over
multiple servers, where the data storage, communication and processing
transactions are fully controlled, costs of communication are symmetric,
and the patients information privacy and security are met. We propose
fully connected sites on a web telemedicine heterogeneous network
system with different bandwidths; 128 kbps, 512 kbps, or multiples. In
this environment, some servers are used to execute the telemedicine
queries triggered from different web database sites. Few servers are run
the database programs and perform the fragmentation clusteringallocation computing services while the other servers are used to store the
database fragments. Communications cost (ms/byte) is the cost of loading
and processing data fragments between any two sites in WTDS. To
control and simplify the proposed web telemedicine communication
system, we assume that communication costs between sites are symmetric
and proportional to the distance between them. Communication costs
within the same site are neglected.
consistency
in
the
telemedicine
database
system,
IFCA
fragments that carry out allocation decision value of (0) are considered
for allocation process only in order to ensure data availability and faulttolerant in the WTDS. In this case, each fragment should be allocated to
at least one cluster and one site in this cluster. The allocation decision
value ADV is assumed to be computed as the result of the comparison
between the cost of allocating the fragment to the cluster and the cost of
not allocating the fragment to the same cluster. The allocation cost
function is composed of the following sub-cost functions that are required
to perform the fragment transactions locally: cost of local retrieval, cost
of local update to maintain consistency among all the fragments
distributed over the websites, and cost of storage, or cost of remote
update and remote communications (for remote clusters that do not have
the fragment and still need to perform the required transactions on that
fragment). The not allocation cost function consists of the following subcost functions: cost of local retrieval and cost of remote retrievals
required to perform the fragment transactions remotely when the
fragment is not allocated to the cluster.
Data Allocation and Replication
Data allocation techniques aim at distributing the database fragments on
the web database clusters and their respective sites. We introduce a
heuristic fragment allocation and replication computing service to
perform the processes of fragments allocation in the WTDS. Initially, all
fragments are subject for allocation to all clusters that need these
fragments at their sites. If the fragment shows positive allocation decision
value (i.e., allocation benefit greater than zero) for a specific cluster, then
the fragment is allocated to this cluster and tested for allocation at each of
its sites, otherwise the fragment is not allocated to this cluster. This
Doctor
Registration
Send prescription
DB
Database Fragmentation
Fragmentation
Clustering
ADMI
Search
Doctor
Registration
Patient
Registration
Form
Patient
Report
Send
Report
View
prescriptio
LOGIN
Doctor
Patient
USER
Doctor Reg
Form
LOGIN
A
dmin
Patient reg
form
Send
Request
Online Doctors
View Request
Send Response
Database
Disjoint Fragments
Patient
Reports
Hierarchical Clustering
Algorithm
Data Distribution
UML DIAGRAMS
cases. The main purpose of a use case diagram is to show what system
functions are performed for which actor. Roles of the actors in the system
can be depicted.
Login
Doctor Registration
Patient Reports
Send request
View Response
user
Doctor
Login Onlinedoctors
View data
Send prescription
Fragmentation
Clustering
Data Distribution
CLASS DIAGRAM:
In software engineering, a class diagram in the Unified Modeling
Language (UML) is a type of static structure diagram that describes the
structure of a system by showing the system's classes, their attributes,
operations (or methods), and the relationships among the classes. It
explains which class contains information.
ADMIN
Login
USER
Hotel Booking
Upload Hotels ()
Update all datas
Search key ()
Ratings ()
Route API ()
Ranking ()
Travleing time()
Exact Direction()
SEQUENCE DIAGRAM:
Database
Users
Admin
Login
Upload Hotels
Upload Rating
Route API
Hotels Booking
View hotel Details
Search Hotels
Ratings
EXACT TIME
Hotels Booking
ACTIVITY DIAGRAM:
Activity diagrams are graphical representations of workflows of stepwise
activities and actions with support for choice, iteration and concurrency.
In the Unified Modeling Language, activity diagrams can be used to
describe the business and operational step-by-step workflows of
components in a system. An activity diagram shows the overall flow of
control.
Start
USER
Login
ADMIN
SEARCH
HOTELS
RouteTime
API
Exact
VIEW
Update
Ratings
Details
Upload
Hotels
NO lOGIN
Accept
SYSTEM TESTING
TYPES OF TESTS
Unit testing
Unit testing involves the design of test cases that validate that the
internal program logic is functioning properly, and that program inputs
produce valid outputs. All decision branches and internal code flow
should be validated. It is the testing of individual software units of the
application .it is done after the completion of an individual unit before
integration. This is a structural testing, that relies on knowledge of its
construction and is invasive. Unit tests perform basic tests at component
level and test a specific business process, application, and/or system
configuration. Unit tests ensure that each unique path of a business
process performs accurately to the documented specifications and
contains clearly defined inputs and expected results.
Integration testing
combination of components.
Functional test
Invalid Input
Functions
Output
exercised.
Systems/Procedures: interfacing systems or procedures must be invoked.
System Test
System testing ensures that the entire integrated software system meets
requirements. It tests a configuration to ensure known and predictable
results. An example of system testing is the configuration oriented system
integration test. System testing is based on process descriptions and
flows, emphasizing pre-driven process links and integration points.
Test Results: All the test cases mentioned above passed successfully. No
defects encountered.
Test Results: All the test cases mentioned above passed successfully. No
defects encountered.
SCREEN SHOTS:
CONCLUSION
In this work, we proposed a new approach to promote WTDS
performance. Our approach integrates three enhanced computing
services techniques namely, database fragmentation, network sites
clustering and fragments allocation. We develop these techniques to solve
technical challenges, like distributing data fragments among multiple web
servers, handling failures, and making tradeoff between data availability
and consistency. We propose an estimation model to compute
communications cost which helps in finding cost-effective data allocation
solutions. The novelty of our approach lies in the integration of web
database sites clustering as a new component of the process of WTDS
design in order to improve performance and satisfy a certain level of
REFERENCES
[1] J.-C. Hsieh and M.-W. Hsu, A Cloud Computing Based 12-Lead
ECG Telemedicine Service, BMC Medical Informatics and Decision
Making, vol. 12, pp. 12-77, 2012.
[2] A. Tamhanka and S. Ram, Database Fragmentation and Allocation:
An Integrated Methodology and Case Study, IEEE Trans. Systems, Man
and Cybernetics, Part A: Systems and Humans, vol. 28, no. 3, pp. 288305, May 1998.
[3] L. Borzemski, Optimal Partitioning of a Distributed Relational
Database for Multistage Decision-Making Support systems, Cybernetics
and Systems Research, vol. 2, no. 13, pp. 809-814, 1996.
[4] J. Son and M. Kim, An Adaptable Vertical Partitioning Method in
Distributed Systems, J. Systems and Software, vol. 73, no. 3, pp. 551561, 2004.
[5] S. Lim and Y. Ng, Vertical Fragmentation and Allocation in
Distributed Deductive Database Systems, J. Information Systems, vol.
22, no. 1, pp. 1-24, 1997.
[6] S. Agrawal, V. Narasayya, and B. Yang, Integrating Vertical and
Horizontal Partitioning into Automated Physical Database Design, Proc.
ACM SIGMOD Intl Conf. Management of Data, pp. 359-370, 2004.
[7] S. Navathe, K. Karlapalem, and R. Minyoung, A Mixed
2005.
[21] N. Daudpota, Five Steps to Construct a Model of Data Allocation
for Distributed Database Systems, J. Intelligent Information Systems:
Integrating Artificial Intelligence and Database Technologies, vol. 11, no.
2, pp. 153-68, 1998.
[22] Microsoft SQL Server Available from: <http://www.microsoft.
com/sql/editions/express/default.mspx>, 2012.
[23] MySQL 5.6 <http://www.mysql.com/>, 2013.
[24]
OPNET
IT
Guru
Academic,
OPNET
Technologies,
Inc.
<http://www.opnet.com/university_program/itguru_academic_edition/>,2
003.
[25] J. Hauglid, N. Ryeng, and K. Norvag, DYFRAM: Dynamic
Fragmentation and Replica Management in Distributed Database
Systems, Distributed and Parallel Databases, vol. 28, pp. 157-185, 2010.
[26] Z. Wang, T. Li, N. Xiong, and Y. Pan, A Novel Dynamic Network
Data Replication Scheme Based on Historical Access Record and
Proactive Deletion, J. Supercomputing, vol. 62, pp. 227-250, Oct. 2011,
DOI: 10.1007/s11227-011-0708-z. Published online.
[27] S. Khan and I. Ahmad, Replicating Data Objects in Large
Distributed
Database
Systems:
An
Axiomatic
Game
Theoretic
124-129, 2012.
[34] G. Decandia, D. Hastorun, M. Jampani, G. Kakulapati, A.
Lakshman, A. Pilchin, S. Sivasubramanian, P. Vosshall, and W. Vogels,
Dynamo: Amazons Highly Available Key-Value Store, Proc. ACM
Symp. Operating Systems Principles, pp. 205-220, 2007.
[35] http://en.wikipedia.org/wiki/MongoDB, Nov. 2013.
[36] F. Chang, J. Dean, S. Ghemawat, W.C. Hsieh, D.A. Wallach, M.
Burrows, T. Chandra, A. Fikes, and R.E. Gruber, Big Table: A
Distributed Storage System for Structured Data, Proc. Seventh Symp.
Operating Systems Design and Implementation, pp. 205-218, 2006.