當前位置: 首頁>>代碼示例>>Java>>正文


Java Encoder.compressAndBase64Encode方法代碼示例

本文整理匯總了Java中org.voltdb.utils.Encoder.compressAndBase64Encode方法的典型用法代碼示例。如果您正苦於以下問題:Java Encoder.compressAndBase64Encode方法的具體用法?Java Encoder.compressAndBase64Encode怎麽用?Java Encoder.compressAndBase64Encode使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在org.voltdb.utils.Encoder的用法示例。


在下文中一共展示了Encoder.compressAndBase64Encode方法的3個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: writePlanBytes

import org.voltdb.utils.Encoder; //導入方法依賴的package包/類
/**
 * Update the plan fragment and return the bytes of the plan
 */
static byte[] writePlanBytes(VoltCompiler compiler, PlanFragment fragment, AbstractPlanNode planGraph)
throws VoltCompilerException {
    // get the plan bytes
    PlanNodeList node_list = new PlanNodeList(planGraph);
    String json = node_list.toJSONString();
    compiler.captureDiagnosticJsonFragment(json);
    // Place serialized version of PlanNodeTree into a PlanFragment
    byte[] jsonBytes = json.getBytes(Charsets.UTF_8);
    String bin64String = Encoder.compressAndBase64Encode(jsonBytes);
    fragment.setPlannodetree(bin64String);
    return jsonBytes;
}
 
開發者ID:anhnv-3991,項目名稱:VoltDB,代碼行數:16,代碼來源:StatementCompiler.java

示例2: compileToCatalog

import org.voltdb.utils.Encoder; //導入方法依賴的package包/類
public void compileToCatalog(Database db) throws VoltCompilerException {
    // note this will need to be decompressed to be used
    String binDDL = Encoder.compressAndBase64Encode(m_fullDDL);
    db.setSchema(binDDL);

    // output the xml catalog to disk
    BuildDirectoryUtils.writeFile("schema-xml", "hsql-catalog-output.xml", m_schema.toString(), true);

    // build the local catalog from the xml catalog
    fillCatalogFromXML(db, m_schema);
    fillTrackerFromXML();
}
 
開發者ID:anhnv-3991,項目名稱:VoltDB,代碼行數:13,代碼來源:DDLCompiler.java

示例3: prepareApplicationCatalogDiff

import org.voltdb.utils.Encoder; //導入方法依賴的package包/類
private AsyncCompilerResult prepareApplicationCatalogDiff(CatalogChangeWork work) {
        // create the change result and set up all the boiler plate
        CatalogChangeResult retval = new CatalogChangeResult();
//        retval.clientData = work.clientData;
        retval.clientHandle = work.clientHandle;
//        retval.connectionId = work.connectionId;
//        retval.hostname = work.hostname;

        // catalog change specific boiler plate
        retval.catalogURL = work.catalogURL;

        // get the diff between catalogs
        try {
            // try to get the new catalog from the params
            String newCatalogCommands = CatalogUtil.loadCatalogFromJar(work.catalogURL, null);
            if (newCatalogCommands == null) {
                retval.errorMsg = "Unable to read from catalog at: " + work.catalogURL;
                return retval;
            }
            Catalog newCatalog = new Catalog();
            newCatalog.execute(newCatalogCommands);

            // get the current catalog
            CatalogContext context = VoltDB.instance().getCatalogContext();

            // store the version of the catalog the diffs were created against.
            // verified when / if the update procedure runs in order to verify
            // catalogs only move forward
            retval.expectedCatalogVersion = context.catalog.getCatalogVersion();

            // compute the diff in StringBuilder
            CatalogDiffEngine diff = new CatalogDiffEngine(context.catalog, newCatalog);
            if (!diff.supported()) {
                throw new Exception("The requested catalog change is not a supported change at this time. " + diff.errors());
            }

            // since diff commands can be stupidly big, compress them here
            retval.encodedDiffCommands = Encoder.compressAndBase64Encode(diff.commands());
            // check if the resulting string is small enough to fit in our parameter sets (about 2mb)
            if (retval.encodedDiffCommands.length() > (2 * 1000 * 1000)) {
                throw new Exception("The requested catalog change is too large for this version of VoltDB. " +
                                    "Try a series of smaller updates.");
            }
        }
        catch (Exception e) {
            e.printStackTrace();
            retval.encodedDiffCommands = null;
            retval.errorMsg = e.getMessage();
        }

        return retval;
    }
 
開發者ID:s-store,項目名稱:sstore-soft,代碼行數:53,代碼來源:AsyncCompilerWorkThread.java


注:本文中的org.voltdb.utils.Encoder.compressAndBase64Encode方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。