Log in

View Full Version : Archive Database for older vBulletin threads and posts - Here is an idea - anybody?


Quarterbore
05-03-2006, 08:12 PM
My forums are not so huge that this is essential yet but it seems that it would be logical that some type of Archive database and forum code should be possible with vBulletin. What I would like is the ability to have a second database (on the same server would even be OK) where old forum forum posts could be moved to...

First, lets assume we set up a CRON job that looks for posts that have not had any replies in X-days or longer in forum based on a setting in the Forum Manager.

If the thread has not had any replies in the last X-days, then a script would open that thread and first copy the key thread and post information to an archive database. In addition, extra columns would likely be needed to indicate the "current" forum name so that if in the future forums names would change that the archive would still be usable.

Once the thread has been archived, the original thread would be deleted from the current and active forums. Personally, for an archive server, I would not care about any attachments.

Now, if a person did a search on the active forums and they did not find the information they needed they would have an option to search the archive database. This would be usergroup defined and limited...

The Archive search would work like the advanced search where the member would get a list of forums (generated from the forum name as pulled over when archived) plus have the ability to search via Keyword (subject or all), Username (thread or post), and the rest of the criteria.

To make this more user friendly, an AdminCP tool could be built to rename the forum name of threads in the archive for cases when minor forum name changes occur in the future. Additional AdminCP controls might be needed to make some forums only viewable by some usergroups, ability to delete some archive threads (say someone objects to something in an archive), or ???

When threads are pulled from the archive, these threads would be READ ONLY and they would have a special vBulletin files that would search for them and display them. (Say archivethread and archivepost like in the examples that follow: https://vborg.vbsupport.ru/archivethread.php?t=1 or https://vborg.vbsupport.ru/archivepost.php?p=1).

The big advantage of this would be that the primary forums database would be kept to a smaller size with the older threads getting moved to the archive but old thread information would be saved for the future. The main forum database would still contain all the member information and drive the permissions for who can search or view the archives.

I have looked at the code and tried to formulate a plan on how I could do this but I am just not a good enough coder to do this. I don't personally see this as an impossible task and it seems like a mod like this for larger forums might be useful to reduce some of their server load.

I welcome opinions on the idea and I really welcome someone to create a modification like this...

trackpads
05-03-2006, 08:41 PM
I had this thought a while back but not as well as you have researched it. Your point is right on. A second database is perfect.

Great idea!

Zachery
05-03-2006, 10:33 PM
A whole extra license just to run an arcive forum?>

Quarterbore
05-03-2006, 10:45 PM
If it was a big enough forum, sure.... Just the same....

The main forums would have the member info, the current posts, and even the scripts that search and serve the data from the "archive" database.... This would be on the same domain.... Why would that require 2 licenses?

It is just a "LITE" version of old posts inside of the main vBulletin forum in a read only format, right?

The advantage has to do with the amount of time the server would need to spend pulling up the thread info, post info, or just handle the database in general.

Zachery
05-03-2006, 11:22 PM
Eh, might want to look into mysql 5's archivey thing.

Quarterbore
05-03-2006, 11:33 PM
Eh, might want to look into mysql 5's archivey thing.

OK, "mysql 5" isn't a member name here so I assume you are not refering to a forum mod....

If we do this using a server mysql based command, it would be hard for the server to know what forums should be archived or to add attributes to prevent problems later if for some reason you were to delete the forum where the old threads were archived from, right?

It looks like basically the vB_threads and vB_posts tables have the information that would need to be archived... Add an extra field in the vb_threads table where the current forum name could be captured and it is a case of a new database with essentually just these two tables...

I know the code is more complicated then that but not all that much more to get a basic archive database for old posts....

Zachery
05-04-2006, 12:10 AM
mysql is a server program.. you know the one that vbulletin needs to work?
5 is it the version number im refering to
mysql 5 has a archive function. look into it ;)

Quarterbore
05-04-2006, 12:21 AM
mysql is a server program.. you know the one that vbulletin needs to work?
5 is it the version number im refering to
mysql 5 has a archive function. look into it ;)

http://dev.mysql.com/doc/refman/5.0/en/archive-storage-engine.html

https://vborg.vbsupport.ru/external/2006/05/35.gif

I am really quite sure that your server recomendation is not the answer... That is no more of an archive then the vBulletin Archive that we have with our forums now. The current archive is just a different format of the same old same old...

scotty
05-13-2006, 08:42 AM
i've hacked my 3.0.x forum with a little mod: I created a seperate post table and wrote a small function to archive (backup) "old" threads. this posts will be removed from the "original" post table and don't bother the lots of querys to the post table any more.
I will migrate my forum in the next few weeks from 3.0.x to 3.5x and have to rewrite my code for 3.5.x; maybe this part will become a "releasable" mod.

Quarterbore
10-04-2006, 12:14 PM
Still interested in this... Darn I wish I had time to do it... anybody looking for a project?

Paul M
10-04-2006, 09:58 PM
Why not just create an archive forum and move old threads to it ?

Quarterbore
10-05-2006, 12:37 AM
In essence that is what I would be doing... Just doing it on the same domain so that the archives are available to my members.

So if my website is at DOMAIN and forums at DOMAIN/FORUMS the archive could sit at DOMAIN/ARCHIVES.

If I go the way you suggest, then the permissions on the second database could be set to allow a select few to edit posts while other usergroups would be read only. Lastly, I would just need to share the user table from the primary database with the secondary one.

I will get to this one of these days... I hope!

Paul M
10-05-2006, 01:15 AM
I think you misunderstood.

I mean a simple archive forum, not a whole new board, just a forum on your existing board - to move threads into - why the need to overcomplicate it as you seem to be describing ?

Quarterbore
10-05-2006, 01:32 AM
The problem with that is you lose everything that makes vBulletin so great... By having an archive database with the forums, threads, and posts remaining associated with their original forum you can still use the same usergroup permissions... PLUS perhaps put in additional permissions to use the archives.

Now, if you mean to just double the forums on my site... I think we have about 50-forums on my website so to double that would make my head explode... well, I guess I could do that but then creating the searches to only look at the archives would be a nightmare (I think?).

john1744
10-05-2006, 05:48 AM
I found that my forum slows down every time we get around 2 million posts (about every 4 months now) so we have to delete posts and start over as we don't have the funds to invest in better server solutions.

A separate database would solve that issue.