#Steps:
-
- Generate data files from python scripts.
-
- Use pig scripts to process the data and extract important information in structured format and store it in txt files,upload the files to HDFS.
-
- Store the processed data in structured format in hive tables.
-
- Use hive queries to extract valuable insights from the data such as top 5 products purchased, distribution of payment methods etc.
-
- Store the hive queries data into mysql database.
-
- Connect django with mysql database to get the valuable insights and show analytics on user interface.
-
- Repeat the above steps periodically using cron job/scheduler
#Step 1:
Scripts to create data files are stored in datascripts folder. names of py files are:
- advertiselog.py
- productlog.py
- serverlog.py
you can create new log files by tunning the script or use the already created files from datascript folder. names of log files are:
- advertise.log
- server.log
- product.log
#Step 2: set the load path of data files in pigscripts based on your file systems and run the scripts, output will be stored in pigoutputs folder. names of pig scripts are:
- pigproduct.pig
- advertise.pig
- serverlogs.pig
and then upload the pig output files to hdfs into:
- /ecommercedata/logindata/
- /ecommercedata/cartdata/
- /ecommercedata/purchasedata/
- /ecommercedata/pviewdata/
- /ecommercedata/advertisedata/
- /ecommercedata/serverdata/
based on how many files pig generates, you need to add those many to hdfs.
#Step 3:
now first run the initialisehive.hiveql which will create database and table into your system. then run hiveinsert.hiveql which will insert pig output data to hive tables.
#Step 4:
now run the hive queries and store the output into folder called hiveoutputs.
queries and their output filename are:
- adv1.hiveql --> a1.txt
- adv2.hiveql --> a2.txt
- adv3.hiveql --> a3.txt
- productquery.hiveql --> p1.txt
- productquery1.hiveql --> p2.txt
- productquery2.hiveql --> p3.txt
- productquery3.hiveql --> p4.txt
- productquery4.hiveql --> p5.txt
- ser1.hiveql --> s1.txt
- ser2.hiveql --> s2.txt
- ser3.hiveql --> s3.txt
#Step 5:
now run the python script called pythonmysql.py which will collect hive output and store in mysqldatabase. you would need to setup the database connection mentioned in script based on parameters in your system.
#Step 6:
- install django,python
- django project is in djangohive
- run the following commands:
- python manage.py migrate which will create tables into database.
- python manage.py runserver which will start the server
- now go to localhost:8000/dashboard which is starting page of application.
#Step 7: you can setup cron jobs/schedulers to automate the above steps in your system.