Task #3635: Phase two Morpho implementation
Allow user to specify Morpho storage directory
Currently, morpho's data file structure looks like:
The combination of the scope-name and file name is the identifier. Since new morpho will support different identifier system, such as DOI and UUID, the current data file system wouldn't work.
Moreover, some morpho users complained that the directory which stores the data is opaque.
Here is the proposed new file structure:
The data directory will be separated from .morpho directory. Users can specify any directory which he/she wants.
The first step we will create a new property name "morphoDataDirectory" in the configuration file. The value will be the data directory path. The default value is "MorphoData". If it is the default value, the file path will be /user-home-directory/MorphoData. Under the specified the data directory, morpho will automatically generates a sysmeta directory to store the system metadata if the directory doesn't exist.
The second step, morpho will provide a GUI for users to specify the directory. Also, morpho may support multiple data directories.
#2 Updated by Jing Tao about 10 years ago
Structure in the .morpho:
Traditionally, morpho keeps the unsaved data file in temp. However, if user clear the temp directory even though he may have incomplete package. This can cause the package miss data files. So I propose the unsaved data file will be stored in incomplete directory which can be persistent.
Some other files wil be stored in temp ( i am not sure if we will need it any more).
After user specifies a local store, the directory structure will look like:
#4 Updated by Chris Jones about 10 years ago
In order to allow data managers to have more control over file names for their data files and metadata files, morpho needs a means of tracking local filenames against the object identiifier, and optionally tracking a 'network copy' of the object. For instance, morpho could maintain an internal h2 SQL database with a table such as:
pid local_uri dataone_uri
doi:10.6085/AA/CMRX00_XXXITBDXLSR02_20060618.50.5 file:///Users/frenockm/PISCO/metadata/CMRX00_XXXITBDXLSR02_20060618.50.5.xml https://cn.dataone.org/cn/v1/resolve/doi:10.6085/AA/CMRX00_XXXITBDXLSR02_20060618.50.5
This may also be implemented as a SOLR index as opposed to SQL tables. When the user changes a local URI outsie of Morpho (renames a file), Morpho may need to bring up a dialog asking for the location of the missing file (likely on startup).
#5 Updated by Jing Tao about 10 years ago
Chris' suggestion is great. We will address the issue on the task 3074.
The user specified directory only store the eml documets generating by morpho, and the downloaded eml and data files from network by Morpho.
The local file which is imported to morpho will keep at the original location. Morpho wouldn't copy it to its local store, just assign it an identifier and the identifer-filename.mapping will redirect the identifier to the local file location. If user modify the local file by an external editor, then the next time morpho open the package and it will prompt the user either to assign a new id to the local file or ask user to import the data file again depending on the nature of the change. If user modify the file in morpho, morpho will copy the old version to the central store with the hash string of the old identifier and overwrite the orginal file. Of course a new identifier will be assigned to the new file.
Where we store the system metadata and ore information?
Store them in the file system described above.
advantage - they persist in a safer way than in an embedded database. It is easy to take a look for the trouble shooting.
disadvantage - every time we need to parse them to get the information. But those files are pretty small, it maybe is not very expensive.
Store them in a embedded database.
advantage - we don't need to parse the documents and only do sql commands to get information.
disadvantage - if the database crashes, it will be a disaster. It is hard to take a look for the trouble shooting since it is a binary format.
#7 Updated by Ben Leinfelder almost 10 years ago
- Subject changed from Morpho's new data file system. to Allow user to specify Morpho storage directory
- Category set to Morpho
Moving this to 2.x.y target. I think the structure of the filesystem looks like a fine idea, but allowing users to directly edit these files opens up a huge cn of worms in terms of consistency and versioning.