Scaling Write Intensive App (LAMP, MySQL) (Catalog Style Application)
I was wondering if there's anyone out here who has experience with write-intensive data due to file import.
The main requirement is for the business users to be able to import a data that represents relationships between master tables. They should be able to export the same in real-time ( as much as possible).
Setup:
- front-end (php) application writes on a MASTER database.
- Replication Setup - Master DB is replicated to two SLAVE DB servers.
- one of the SLAVE server is used as "read" database for front-end UI interactions (heavy queries).
- The same SLAVE server is also used for "EXPORTING" data based on a query that has been previewed on the front-end. (Lots of JOIN table).
The main challenge has been replication log. The users are not happy with the performance & data not b开发者_运维技巧eing available on the front-end even though the files they've import has been processed already. Replication LAG is the culprit.
Moving to NoSQL i.e. is the LONG Term goal. Still want to improve the performance for now. By the way, the application is used internally but is hosted in a well-known hosting company. Number of users is around 150 users.
Imported data is around 200k - 800k lines. Each line represent a single row.
Any inputs would be appreciated :)
There are many factors that play a part in improving MySQL replication lag. Perhaps this podcast about MySQL replication on Youtube by their DBA might provide you with some tips & pointers:
http://itc.conversationsnetwork.org/shows/detail3299.html
Hope this helps.
@Wrikken,
(Answering via the answer box)
Yes, lots of "inserts" and updates. The application makes use of temporary tables (i.e. real physical table with some prefix) to insert preliminary data. And does a lot of INSERT INTO .. SELECT * FROM ..
This is causing a lot of statements being replicated to the SLAVE which in the end temporary tables are being dropped. I have already recommeded that such type of table should be excluded from the list of tables to be replicated and instead of using INSERT INTO ... SELECT * FROM the application should just SELECT everything from build the INSERT, UPDATE, DELETE statements on the application memory space and execute the SQL statment. It should lessen the number of temp table related statements from being replicated.
 
         加载中,请稍侯......
 加载中,请稍侯......
      
精彩评论