Talk:OstDB DEV Foosic: Difference between revisions
		
		
		
		Jump to navigation
		Jump to search
		
| Epoximator (talk | contribs)  (New page: === Protocol === I don't see any reasons to use cleartext/ascii here (?): * this is an internal protocol, so it don't have to be readable for the masses * it'll be pain and simple withouth...) | Epoximator (talk | contribs)  m (→Protocol) | ||
| Line 2: | Line 2: | ||
| I don't see any reasons to use cleartext/ascii here (?): | I don't see any reasons to use cleartext/ascii here (?): | ||
| * this is an internal protocol, so it don't have to be readable for the masses | * this is an internal protocol, so it don't have to be readable for the masses | ||
| * it'll be pain and simple  | * it'll be pain and simple without much need for future expansions | ||
| * all the datatypes used is well defined (constant length) | * all the datatypes used is well defined (constant length) | ||
| I assume we'll use encryption? at least between redirector and matching servers | I assume we'll use encryption? at least between redirector and matching servers | ||
| --[[User:Epoximator|Epoximator]] 13:29, 21 May 2007 (UTC) | |||
| === OLD Stuff === | === OLD Stuff === | ||
Revision as of 13:29, 21 May 2007
Protocol
I don't see any reasons to use cleartext/ascii here (?):
- this is an internal protocol, so it don't have to be readable for the masses
- it'll be pain and simple without much need for future expansions
- all the datatypes used is well defined (constant length)
I assume we'll use encryption? at least between redirector and matching servers --Epoximator 13:29, 21 May 2007 (UTC)
OLD Stuff
alternatively:
- avdump sends data to anidb2 udpapi
- anidb2 udpapi stores all data
- anidb2 cronjob sends fingerprint to matching slaves
- matching slaves returns best matches: ofid,match value
- anidb2 cronjob sends fingerprint,ofid to the server with the worst results (or none) for storage.
- this slave is now responsible for this fingerprint
- storage would be ofid,length,avg_fit,avg_dom,fp
- an identifier for the slave should be stored in ostfiletb for later administration of slaves/fingerprints
 
- anidb2 cronjob adds new ostfile relations based on the results
--Epoximator 08:39, 10 May 2007 (UTC)
I see several problems with this approach:
- there is no natural relation between ofids and fingerprints, fingerprints are matched to songs, not files. However you imply such a relation by using ofids as ids for fingerprints on the slave servers. I.e. a case where this would become a problem:
- Lets say a fingerprint is known to anidb and is loosely (foosic fp match) shared between multiple files. Your approach would relate all these files to one another (or to one specific file from the set). If it now becomes apparent that one of these files, possibly the one whose ofid you used as fingerprint id, is in fact wrongly matched to the song in question and is moved to another song, we'd effectively be changing the primary key of the fingerprint, on multiple decentralized servers... bad idea
- And using the songid instead won't work either. As there won't be a ostfile<->song match at the time when the fingerprints are processed. I.e. we might end up with a group of files which all share similar fingerprints but which are all not yet matched to a song. The fact that tey're all sharing a similar fingerprint is highly relavant for the matching process though. So we can't delay the fingerprint analysis inorder to be able to use the song ids as keys. Which is why I'd suggest that we just create new unique ids for the fingerprints.
 
- i assumed, and still do, that fp is unique per encode (ofid) and not song. even if two fps are equal they would still be treated as two different ones throughout the system (they would just have a very good match value). so the relation would be ostfiletb >-< ostfiletb. then, on top of this, rows in songtb relate to one row each in ostfiletb (which the other relations can be derived from). if we don't want this redundancy we shouldn't store fps in ostfiletb at all, but rather in their own table where uniqueness is preserved (and with own ids). then you would have ostfiletb>-fptb-(<)songtb.
 
- load balancing:
- what are "matching slaves" ?
 
- a matching slave is a puter with a matching daemon running
 
- what do you mean with "the server with the worst results (or none) for storage"? the error margin on found matches is hardly useful to determine the average load each server is under. Instead I'd suggest to return the total number of stored fingerprints on each server with the reply and store the fingerprint on the server with the smallest fingerprint count.
 
- the work load is not defined by how many fps there are in total, but how many that are selected for matching. the idea is that if a slave come up with no results, or only bad ones, then it should have the new fp because it is "unique" on that server. ie. fps should be distribued so that similar fps are spread as much as possible. but the decision depends on how the selection is done:
- select fp from fptb order by 2*abs(len-?)+abs(fit-?)+abs(dom-?) asc limit X (use results)
- select fp from fptb where abs(len-?)<X and abs(fit-?)<Y and abs(dom-?)<Z (use count)
- it will of course not balance good if the slaves have very different hw (and/or additional tasks). we should consider processing time also, but per request
 
- "returns best matches", only if the match is good enough to be considered a real "match". So in many cases most of the slaves would probably reply that the fingerprint is unknown.
 
- yes, that's true, at least in the beginning. it only depends on how many versions there are of each song and how many of them we have registered. (but one point is that we don't know what's considered a good match atm. it has to be adjusted)
 
- I do agree that it is probably useful to remember which server a specific fingerprint id is stored on. The easiest/efficient approach for that would be to use a couple of the high bits of the ids to store that info. I.e. we could use the highest 4bits (skipping the sign bit) of a 32bit signed integer, leaving us with an effective 27bit room of ids. I guess we wouldn't reach the 130 million entry mark anytime soon. Neither are we likely to fork of to more than 16 servers. Both numbers could easily be extended later by switching to int8 values and using a larger room in the header for the server selection, i.e. 16bit. That would mean that each server would have it's own unique sequence for fingerprint ids (starting at 0) and we'd simply AND a server specific bitmask to it to obtain the external id, when transmitting the data. Which means that the DB ids on the servers are not unique and will not change if we ever decide to change the splitting between server bits and id bits.
 
- yes, it's useful for administration. if one slave dies it should be simple to redistribute the "lost" fps between the remaining slaves or to a new one. we should also redistribute fps when new slaves are added in general. i still think that the ids should be created and stored in the main db, but it doesn't really matter. i think it would be safer and more clean, though.
 
- "anidb2 cronjob adds new ostfile relations based on the results", in cases where we already know other files with a matching fingerprint and those are already related to a specific song. If the other similar files are also "song-less", then the matching/group information would remain unused until someone opens the manual matching website. Where those files could be grouped together and would by default all be related to the song which the user selects.
- yes. the matching is fully automated and is completely unrelated to the songs until someone adds those relations manually. it is of course possible to generate songs to based on the metadata, though. (initially, at least)
- --Epoximator 17:53, 11 May 2007 (UTC)
 
- Exp 13:45, 11 May 2007 (UTC)Italic text